gpt4 book ai didi

Spring DI applicationContext.xml xsi :schemaLocation used?到底是怎么回事

转载 作者:行者123 更新时间:2023-12-02 17:40:40 25 4
gpt4 key购买 nike

注意:我提到的测试项目可以通过以下方式下载:

git 克隆 https://github.com/mperdikeas/so-spring-di-appcontext-schemalocation.git

..并使用“ant run”运行。

我“理解”XML 命名空间名称仅用作不透明标识符,并不意味着用作 URI ( wikipedia )。我还“理解”XML 模式位置旨在提供有关模式文档的实际位置的提示,并且作为提示,在实践中并未使用( w3.org )。考虑到这一点,我一直通过修改 applicationContext.xml 来尝试一个简单的 Spring DI 应用程序(在简单的 J2SE 设置中使用)。这是起始版本:

<beans xmlns             = "http://www.springframework.org/schema/beans"                                             
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xmlns:context = "http://www.springframework.org/schema/context"
xmlns:p = "http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd">

<context:component-scan base-package="atm"/>
<context:property-placeholder location="classpath:META-INF/spring/atm.properties"/>

<bean id="soapTransport_" class="atm.SoapATMTransport" p:retries="${transport.retries}"/>

当我执行“sudo ifconfig eth0 down”时,项目运行完美,这与运行时一致,无需从 schemaLocations 中获取任何内容。然而,当我通过向每对中的第二个 URL 添加一个简单的下划线来破坏 schemaLocations 时,我收到了以下投诉:

 [java] org.springframework.beans.factory.xml.XmlBeanDefinitionStoreException: Line 10 in XML document from class path resource [META-INF/spring/applicationContext.xml] is invalid; nested exception is org.xml.sax.SAXParseException; lineNumber: 10; columnNumber: 100; cvc-elt.1: Cannot find the declaration of element 'beans'.
[java] at org.apache.tools.ant.taskdefs.ExecuteJava.execute(ExecuteJava.java:194)
[java] at org.apache.tools.ant.taskdefs.Java.run(Java.java:771)
[java] at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:221)
[java] at org.apache.tools.ant.taskdefs.Java.executeJava(Java.java:135)
[java] at org.apache.tools.ant.taskdefs.Java.execute(Java.java:108)
[java] at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
[java] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
[java] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
[java] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
[java] at java.lang.reflect.Method.invoke(Method.java:601)
[java] at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
[java] at org.apache.tools.ant.Task.perform(Task.java:348)
[java] at org.apache.tools.ant.Target.execute(Target.java:390)
[java] at org.apache.tools.ant.Target.performTasks(Target.java:411)
[java] at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
[java] at org.apache.tools.ant.Project.executeTarget(Project.java:1368)
[java] at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
[java] at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
[java] at org.apache.tools.ant.Main.runBuild(Main.java:809)
[java] at org.apache.tools.ant.Main.startAnt(Main.java:217)
[java] at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
[java] at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)

这似乎表明 Spring DI 运行时使用 xsi:schemaLocation 处每对中的第二个 URL 作为某种标识符(由于没有网络访问,因此在其逻辑中进行了硬编码)。所以我的假设是 Spring DI 运行时为每个命名空间使用两种标识符:xmlns 标识符用于唯一标识命名空间(用作不透明字符串)和 schemaLocation> 唯一标识该命名空间的架构版本的标识符(再次用作不透明字符串)。 IE。 schemaLocation 实际上用于(以一种扭曲的方式?因为这似乎不是 w3c 文档的意图)对命名空间进行版本控制。此外,在这种情况下,为什么 Spring DI 运行时不会提示“p”命名空间缺少 schemaLocation。我的思维模式正确吗?

最佳答案

发生的情况是这样的:

  • XML 模式允许您定义 XML 命名空间的别名(短名称)。从技术上讲,所有 namespace 都由完整的 URI 标识,但这会非常麻烦 - 因此您可以使用简短的别名,例如 contextp。还有一个由 xmlns 属性表示的默认命名空间

  • 默认情况下,XML 解析器假定 namespace URI 也是 XSD 文件 URL 位置。这种情况经常发生,但规范中并不要求这样做。如果您不提供 schemaLocation 属性,这也是 Spring 中的 XML 解析器的工作方式。

  • schemaLocation 用于从命名空间 URI 映射到 XSD 文件物理位置 (URL)。当架构命名空间指向有效的 XSD URL 时使用它(请参阅 MSDN on schemaLocation )。

  • 最后但并非最不重要的一点是,Spring 添加了另一层,将 Internet URL 转换为 CLASSPATH 上的本地文件。这样,您的应用程序就可以在没有互联网连接的情况下启动(或者当 springframework.org 网站关闭时)。

如果您搜索项目库,您会发现几个名为 spring.schemas 的文件。这些文件包含类似于下面的行(从 spring-context.jar 中找到的文件中提取,我添加了对齐方式):

http\://www.springframework.org/schema/context/spring-context.xsd= org/springframework/context/config/spring-context-3.1.xsd
http\://www.springframework.org/schema/jee/spring-jee.xsd= org/springframework/ejb/config/spring-jee-3.1.xsd
http\://www.springframework.org/schema/lang/spring-lang.xsd= org/springframework/scripting/config/spring-lang-3.1.xsd
http\://www.springframework.org/schema/cache/spring-cache.xsd= org/springframework/cache/config/spring-cache-3.1.xsd

关于Spring DI applicationContext.xml xsi :schemaLocation used?到底是怎么回事,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10768873/

25 4 0