Spring schemaLocation не работает при отсутствии подключения к Интернету

107

Я использую Spring, и у application-context.xmlменя есть следующие определения:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xmlns:util="http://www.springframework.org/schema/util"
   xmlns:context="http://www.springframework.org/schema/context"
   xmlns:aop="http://www.springframework.org/schema/aop"
   xmlns:tx="http://www.springframework.org/schema/tx"
   xmlns:p="http://www.springframework.org/schema/p"
   xmlns:security="http://www.springframework.org/schema/security"
   xsi:schemaLocation="
   http://www.springframework.org/schema/beans 
   http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
   http://www.springframework.org/schema/util 
   http://www.springframework.org/schema/util/spring-util-2.0.xsd
   http://www.springframework.org/schema/context
   http://www.springframework.org/schema/context/spring-context-2.1.xsd
   http://www.springframework.org/schema/tx
   http://www.springframework.org/schema/tx/spring-tx.xsd
   http://www.springframework.org/schema/aop
   http://www.springframework.org/schema/aop/spring-aop-2.0.xsd
   http://www.springframework.org/schema/security
   http://www.springframework.org/schema/security/spring-security-2.0.xsd"
   >

.....

Когда мое интернет-соединение потеряно, я не могу запустить свое приложение через tomcat или причал.

Это дает:

[main] WARN  org.springframework.beans.factory.xml.XmlBeanDefinitionReader - Ignored XML validation warning
org.xml.sax.SAXParseException: schema_reference.4: Failed to read schema document '/spring-beans-2.0.xsd', because 1) could not find the document; 2) the document could not be read; 3) the root element of the document is not <xsd:schema>.
    at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:195)
    at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.warning(ErrorHandlerWrapper.java:96)
    at com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:380)
    at com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:318)
    at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.reportSchemaErr(XSDHandler.java:2541)
    at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.reportSchemaWarning(XSDHandler.java:2532)
    at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.getSchemaDocument(XSDHandler.java:1836)
    at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.parseSchema(XSDHandler.java:531)
    at com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaLoader.loadSchema(XMLSchemaLoader.java:552)
    at com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaValidator.findSchemaGrammar(XMLSchemaValidator.java:2408)
    at com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaValidator.handleStartElement(XMLSchemaValidator.java:1753)
    at com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaValidator.startElement(XMLSchemaValidator.java:685)
    at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.scanStartElement(XMLNSDocumentScannerImpl.java:400)
    at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl$NSContentDriver.scanRootElementHook(XMLNSDocumentScannerImpl.java:626)
    at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl$FragmentContentDriver.next(XMLDocumentFragmentScannerImpl.java:3095)
    at com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl$PrologDriver.next(XMLDocumentScannerImpl.java:921)
    at com.sun.org.apache.xerces.internal.impl.XMLDocumentScannerImpl.next(XMLDocumentScannerImpl.java:648)
    at com.sun.org.apache.xerces.internal.impl.XMLNSDocumentScannerImpl.next(XMLNSDocumentScannerImpl.java:140)
    at com.sun.org.apache.xerces.internal.impl.XMLDocumentFragmentScannerImpl.scanDocument(XMLDocumentFragmentScannerImpl.java:510)
    at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:807)
    at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(XML11Configuration.java:737)
    at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(XMLParser.java:107)
    at com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:225)
    at com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:283)
    at org.springframework.beans.factory.xml.DefaultDocumentLoader.loadDocument(DefaultDocumentLoader.java:75)
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:396)
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:342)
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:310)
    at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:143)
    at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:178)
    at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:149)
    at org.springframework.web.context.support.XmlWebApplicationContext.loadBeanDefinitions(XmlWebApplicationContext.java:124)
    at org.springframework.web.context.support.XmlWebApplicationContext.loadBeanDefinitions(XmlWebApplicationContext.java:92)
    at org.springframework.context.support.AbstractRefreshableApplicationContext.refreshBeanFactory(AbstractRefreshableApplicationContext.java:123)
    at org.springframework.context.support.AbstractApplicationContext.obtainFreshBeanFactory(AbstractApplicationContext.java:423)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:353)
    at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:255)
    at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:199)
    at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:45)
    at org.mortbay.jetty.handler.ContextHandler.startContext(ContextHandler.java:548)
    at org.mortbay.jetty.servlet.Context.startContext(Context.java:136)
    at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1250)
    at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:517)
    at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:467)
    at org.mortbay.jetty.plugin.Jetty6PluginWebAppContext.doStart(Jetty6PluginWebAppContext.java:115)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
    at org.mortbay.jetty.handler.HandlerCollection.doStart(HandlerCollection.java:152)
    at org.mortbay.jetty.handler.ContextHandlerCollection.doStart(ContextHandlerCollection.java:156)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
    at org.mortbay.jetty.handler.HandlerCollection.doStart(HandlerCollection.java:152)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
    at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
    at org.mortbay.jetty.Server.doStart(Server.java:224)
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
    at org.mortbay.jetty.plugin.Jetty6PluginServer.start(Jetty6PluginServer.java:132)
    at org.mortbay.jetty.plugin.AbstractJettyMojo.startJetty(AbstractJettyMojo.java:441)
    at org.mortbay.jetty.plugin.AbstractJettyMojo.execute(AbstractJettyMojo.java:383)
    at org.mortbay.jetty.plugin.AbstractJettyRunMojo.execute(AbstractJettyRunMojo.java:210)
    at org.mortbay.jetty.plugin.Jetty6RunMojo.execute(Jetty6RunMojo.java:184)
    at org.apache.maven.plugin.DefaultPluginManager.executeMojo(DefaultPluginManager.java:483)
    at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoals(DefaultLifecycleExecutor.java:678)
    at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeStandaloneGoal(DefaultLifecycleExecutor.java:553)
    at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoal(DefaultLifecycleExecutor.java:523)
    at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoalAndHandleFailures(DefaultLifecycleExecutor.java:371)
    at org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeTaskSegments(DefaultLifecycleExecutor.java:332)
    at org.apache.maven.lifecycle.DefaultLifecycleExecutor.execute(DefaultLifecycleExecutor.java:181)
    at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:356)
    at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:137)
    at org.apache.maven.cli.MavenCli.main(MavenCli.java:356)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.codehaus.classworlds.Launcher.launchEnhanced(Launcher.java:315)
    at org.codehaus.classworlds.Launcher.launch(Launcher.java:255)
    at org.codehaus.classworlds.Launcher.mainWithExitCode(Launcher.java:430)
    at org.codehaus.classworlds.Launcher.main(Launcher.java:375)
2009-11-13 15:31:25,675 [main] ERROR org.springframework.web.context.ContextLoader - Context initialization failed
org.springframework.beans.factory.xml.XmlBeanDefinitionStoreException: Line 23 in XML document from class path resource [application-context.xml] is invalid; nested exception is org.xml.sax.SAXParseException: cvc-elt.1: Cannot find the declaration of element 'beans'.
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:404)
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:342)
    at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinit........

Есть предложения, как это исправить?

Алтуг
источник

Ответы:

115

Нет необходимости использовать classpath: protocol в вашем URL-адресе schemaLocation, если пространство имен настроено правильно и файл XSD находится в вашем пути к классам.

В документе Spring « Регистрация обработчика и схемы » показано, как это должно быть сделано.

В вашем случае проблема, вероятно, заключалась в том, что jar-файл spring-context в вашем пути к классам не был 2.1. Вот почему изменение протокола на classpath: и размещение конкретного XSD 2.1 в вашем пути к классам устранило проблему.

Из того, что я видел, для основного XSD, содержащегося в spring- * jar, определены две схемы. Один раз для разрешения URL схемы с версией и один раз без нее.

В качестве примера см. Эту часть содержимого spring.schemas в файле spring-context-3.0.5.RELEASE.jar:

http\://www.springframework.org/schema/context/spring-context-2.5.xsd=org/springframework/context/config/spring-context-2.5.xsd
http\://www.springframework.org/schema/context/spring-context-3.0.xsd=org/springframework/context/config/spring-context-3.0.xsd
http\://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.0.xsd

Это означает, что (в xsi: schemaLocation)

http://www.springframework.org/schema/context/spring-context-2.5.xsd 

будет подтверждено против

org/springframework/context/config/spring-context-2.5.xsd 

в пути к классам.

http://www.springframework.org/schema/context/spring-context-3.0.xsd 

или

http://www.springframework.org/schema/context/spring-context.xsd

будет подтверждено против

org/springframework/context/config/spring-context-3.0.xsd 

в пути к классам.

http://www.springframework.org/schema/context/spring-context-2.1.xsd

не определен, поэтому Spring будет искать его, используя буквальный URL-адрес, определенный в schemaLocation.

Дэвид Резник
источник
37
Для тех, кому нужно резюме: Spring не может найти схемы в пути к классам. JAR-файл ядра Spring имеет отображение схемы-> имени файла, которое включено в JAR. Если он не может решить эту проблему, он отправится в Интернет.
Alex
Я объявил это так: «http:////www.springframework.org/schema/context http: ///www.springframework.org/schema/context/spring-context-4.0.xsd». У меня есть банка 4.0 в Glassfish / domains / domain1 / lib. Всякий раз, когда я развертываю проект, Glassfish обращается к Интернету. Эта проблема характерна для Glassfish-4.0? (добавлены дополнительные
символы
Я думаю, что новая ссылка «Регистрация обработчика и схемы» должна быть здесь: docs.spring.io/spring/docs/current/spring-framework-reference/…
Дирк
1
@Dirk - эта ссылка, похоже, не работает
Stormcloud
2
@Stormcloud, да, похоже, что исходная ссылка вернулась, а та, которую я предложил, не работает. Вот последняя ссылка на документ: docs.spring.io/spring/docs/current/spring-framework-reference/…
Дирк
28

Я решил это

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:util="http://www.springframework.org/schema/util"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xmlns:p="http://www.springframework.org/schema/p"
       xmlns:security="http://www.springframework.org/schema/security"
       xsi:schemaLocation="
       http://www.springframework.org/schema/beans 
       http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
       http://www.springframework.org/schema/util 
       http://www.springframework.org/schema/util/spring-util-2.0.xsd
       http://www.springframework.org/schema/context
       classpath:spring-context-2.1.xsd
       http://www.springframework.org/schema/tx
       http://www.springframework.org/schema/tx/spring-tx.xsd
       http://www.springframework.org/schema/aop
       http://www.springframework.org/schema/aop/spring-aop-2.0.xsd
       http://www.springframework.org/schema/security
       http://www.springframework.org/schema/security/spring-security-2.0.xsd"
       >

classpath:spring-context-2.1.xsdэто ключ для работы в автономном режиме (без подключения к Интернету). Также я скопировал spring-context-2.1.xsdрядом (в том же каталоге) файл application-context.xml

Алтуг
источник
6
Для пользователей intellij, которые могут столкнуться с этим. Это работает, даже если intellij не распознает синтаксис пути к классам внутри schemalLocation и выделяет его как ошибку.
Upgradingdave
Огромное спасибо @DaveParoulek - ошибка сбивала меня с толку, но это абсолютно помогает.
Зак Джонсон,
18

Что-то вроде этого у меня сработало.

xsi:schemaLocation=
"http://www.springframework.org/schema/beans 
             classpath:org/springframework/beans/factory/xml/spring-beans-3.0.xsd
http://www.springframework.org/schema/context 
             classpath:org/springframework/beans/factory/xml/spring-context-3.0.xsd"
божественный нуб
источник
1
Да, это работает, потому что xsd упакован внутри пружинной банки. Так что не нужно проверять на springframework.com, когда вы можете использовать xsd внутри банки :)
Сомайя Кумбера
Это решение сработало для меня, потому что у меня были пружинные зависимости внутри банки, я имею в виду, как внешнюю банку, и без сбоев в Интернете ваше решение работало очень хорошо для меня, большое спасибо, благослови вас Бог.
chiperortiz 06
@godlikeNoob Я пробовал это, но снова выдает ошибку «cvc-elt.1: Не удается найти объявление элемента beans».
Камини
6

На случай, если кто-то придет сюда через тот же корень, что и я, - я столкнулся с этой проблемой, потому что я создавал один JAR со всеми зависимостями, включая Spring JAR. В результате файл spring.schemas в некоторых каталогах META-INF файлов Spring JAR был перезаписан.

Я нашел здесь предлагаемые решения: как создать исполняемую jar на основе Spring с помощью maven?

Эд.
источник
5

Сегодня столкнулся с подобной проблемой. В моем случае виновником был плагин shade, а также сбой на springframework.org. Следующий фрагмент прояснил ситуацию:

<transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
   <resource>META-INF/spring.schemas</resource>
</transformer>
<transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
    <resource>META-INF/spring.handlers</resource>
</transformer>

HTH кто-то

Закюрей
источник
куда нужно добавить приведенный выше фрагмент?
Камини
4

Вы должны проверить , что spring.handlersи spring.schemasфайлы находятся на пути к классам и имеют право содержания.

Это можно сделать с помощью ClassLoader.getResource(..). Вы можете запустить метод с помощью удаленного отладчика в среде выполнения. Настройка расширяемой разработки XML описана в Spring Reference B.5. Регистрация обработчика и схемы .

Обычно файлы должны находиться в банке Spring (springframework.jar / META-INF /) и в пути к классам, когда Spring может быть запущен.

Томас Юнг
источник
1
привет, ваше решение очень сложное; я не понимаю о чем ты? jroller.com/marshbourdon/entry/using_spring_2_x_xml , я пробовал это, но это не работает. Какие-либо предложения ? Работать с веб-приложением, пока нет подключения к Интернету, не может быть сложной задачей. я прав ? Спасибо.
Altug
1
Весна должна работать из коробки. Что-то с вашим путем к классам неверно. Мой ответ содержал лишь некоторые подсказки для анализа вашей проблемы.
Thomas Jung
2

Найти путь к классу

Если вы используете eclipse, щелкните соответствующий файл jar. Перейти -> META-INF-> открыть файл spring.schemas

вы увидите строки примерно так, как показано ниже.

http://www.springframework.org/schema/context/spring-context.xsd=org/springframework/context/config/spring-context-3.1.xsd

скопируйте after = и настройте beans как показано ниже.

<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:util="http://www.springframework.org/schema/util" xmlns:rabbit="http://www.springframework.org/schema/rabbit" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/rabbit classpath:org/springframework/amqp/rabbit/config/spring-rabbit-1.1.xsd http://www.springframework.org/schema/beans classpath:org/springframework/beans/factory/xml/spring-beans-3.1.xsd http://www.springframework.org/schema/context classpath:org/springframework/context/config/spring-context-3.1.xsd http://www.springframework.org/schema/util classpath:org/springframework/beans/factory/xml/spring-util-3.1.xsd">

Santhosh Hirekerur
источник
Я внес это изменение в xml- путь к классам springframework.org/schema/rabbit : org / springframework / amqp / rabbit / config / spring-rabbit-1.6.xsd, но он говорит Не удалось прочитать путь к классам документа схемы: org / springframework / amqp / rabbit / config / spring-rabbit-1.6.xsd '? любое предложение
Лалит Мехра
1

Вам нужно добавить расположение схемы в определение вашего bean-компонента, и тогда их можно будет найти в пути к классам, а не получить по сети. Учитывая ваши проблемы с форматированием, я не уверен на 100%, что вы этого еще не делаете.

<?xml version="1.0" encoding="UTF-8"?>
<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"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd">
<!-- empty: the beans we use are in the base class's context. -->
</beans>
bmargulies
источник
1

Мы решили проблему следующим образом:

DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
factory.setNamespaceAware(true);
factory.setValidating(false); // This avoid to search schema online
factory.setAttribute("http://java.sun.com/xml/jaxp/properties/schemaLanguage", "http://www.w3.org/2001/XMLSchema");
factory.setAttribute("http://java.sun.com/xml/jaxp/properties/schemaSource", "TransactionMessage_v1.0.xsd");

Обратите внимание, что наше приложение является автономным автономным Java-приложением.

джиз
источник
1

Если вы используете eclipse для своей разработки, вам поможет установка плагина STS для Eclipse [из marketPlace для конкретной версии eclipse.

Теперь, когда вы пытаетесь создать новый файл конфигурации в папке (обычно это ресурсы) внутри проекта, параметры будут иметь «Папку Spring», и вы можете выбрать параметр «Spring Bean Definition File» Spring> Spring Bean Configuation File.

Если выбран этот параметр, при выполнении шагов вам будет предложено выбрать пространства имен и конкретные версии:

Таким образом можно исключить возможность наличия несуществующей jar или старой версии.

Я бы тоже выложил изображения, но моя репутация довольно низкая .. :(

Рошан Хандельвал
источник
1

Проблема заключается в файлах JAR, которые вы используете в своем приложении.

Что я сделал, и это сработало, так это залезть внутрь JAR для SPRING-CORE, SPRING-BEANS, SPRING-CONTEXT, SPRING-TX, которые соответствуют версии, которую я использую. В папке META-INF я объединил все spring.handlers и spring.schemas, которые входят в эти JAR.

Я убил двух зайцев одним выстрелом, решил проблему схем, так что это тоже корректно работает в автономном режиме.

PS Я попробовал плагин maven для SHADE и трансформаторов, но это не сработало.

Хосе Луис Мендес
источник
Как вы решили эту проблему, не могли бы вы помочь мне понять это. Я в нужде.
Камини
1

У меня была такая проблема. Для потомков моим исключением были:

org.xml.sax.SAXParseException; lineNumber: 7; columnNumber: 117;
schema_reference.4: Failed to read schema document
'http://www.springframework.org/schema/beans/spring-beans-4.2.xsd'

Я решил это, когда понял версию, spring-beansуказанную в моем Mavenpom.xml была 4.1.x, что означает, что конкретная.xsd не может быть найдена в пути к классам.

Это долгое время маскировалось, потому что я обычно нахожусь в сети, поэтому я подумал, что отключение «сломало» сборку. Но на самом деле это не имело никакого отношения к этому. Обновление моей pom.xmlдля указания правильной версии spring-beans, а именно 4.2.xисправлено.

Стюарт
источник
1

У меня была такая же проблема, когда я использовал Spring-context версии 4.0.6 и spring-security версии 4.1.0.

При изменении версии spring -security на 4.0.4 (поскольку 4.0.6 Spring-security недоступна) в моем pom и security xml -> schemaLocation, она компилируется без Интернета.

Это означает, что вы также можете решить эту проблему:

  • изменение spring -security на более старую или ту же версию, чем spring-context.

  • изменение spring-context на более новую или ту же версию, чем spring-security.

(в любом случае spring-context должен быть более новым или той же версии, что и spring-security)

Яситха Бандара
источник
0

Я хотел бы добавить к этому обсуждению еще один аспект. В ОС Windows я заметил, что когда файл jar, содержащий схему, хранится в каталоге, путь которого содержит символ пробела, например, как в следующем примере

"c:\Program Files\myApp\spring-beans-4.0.2.RELEASE.jar"

тогда указания URL-адреса расположения схемы следующим образом недостаточно, если вы разрабатываете какое-то отдельное приложение, которое также должно работать в автономном режиме

<beans
 xsi:schemaLocation="
   http://www.springframework.org/schema/beans org/springframework/beans/factory/xml/spring-beans-2.0.xsd"
    />

Я узнал, что результатом такого разрешения URL-адреса расположения схемы является файл, который имеет путь, подобный следующему

"c:\Program%20Files\myApp\spring-beans-4.0.2.RELEASE.jar"

Когда я запустил свое приложение из другого каталога, который не содержал пробела на своем пути, разрешение местоположения схемы работало нормально. Может кто сталкивался с подобными проблемами? Тем не менее я обнаружил, что протокол пути к классам отлично работает в моем случае

<beans
 xsi:schemaLocation="
   http://www.springframework.org/schema/beans classpath:org/springframework/beans/factory/xml/spring-beans-2.0.xsd"
    />
Дамиано
источник
0

Я тоже столкнулся с этой похожей проблемой. В моем случае разрешение совсем другое. Вот мой XML-файл весеннего контекста:

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

Я не указываю версию xsd, поскольку хочу, чтобы Spring использовала последнюю версию xsd внутри зависимостей Spring. Версия spring, которую использовало мое приложение, была spring-beans-4.3.1.RELEASE.jar: 4.3.1.RELEASE, и когда я собираю свое приложение в jar, все зависимости Spring существуют в моем пути к классам. Однако при запуске контекста приложения Spring я получил следующую ошибку:

org.xml.sax.SAXParseException: schema_reference.4: Failed to read schema document 'http://www.springframework.org/schema/beans/spring-beans.xsd', because 1) could not find the document; 2) the document could not be read; 3) the root element of the document is not <xsd:schema>.

После трудного устранения неполадок я обнаружил, что проблема связана с index.list внутри папки META-INF моего файла jar. С файлом index.list обработчики пространств имен Spring не могут быть обнаружены для правильного анализа XML-контекста приложения Spring. Подробнее об этом весеннем выпуске SPR-5705 читайте.

Удалив индексирование из моего maven-jar-plugin , мне удалось решить проблему. Надеюсь, это сэкономит время людям, имеющим такую ​​же проблему.

Энди Нг
источник
0

Просто убедитесь, что соответствующий файл spring jar находится в пути к классам среды выполнения. В моем случае нам не хватало spring-tx-4.3.4.RELEASE.jar из пути к классам времени выполнения. После добавления этой банки проблема была решена.

Хари
источник
0

Если на вашей платформе нет подключения к Интернету и вы используете Eclipse, выполните следующие действия (это решает мою проблему)

  1. Найдите точные файлы xsd (вы можете распаковать эти файлы из их jar-файлов. Например, spring-beans-xyxsd в spring-beans-xyzRELEASE.jar)
  2. Добавьте эти файлы xsd в каталог Eclipse XML. (Настройки-> XML-> Каталог XML, Добавить файлы)
  3. Добавьте расположение этих файлов в файл конфигурации. (Будьте осторожны, напишите точную версию файла)

Пример:

xsi: schemaLocation = " http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-xyxsd "

gbii
источник
-1

Удалите jar-файлы, которые вы недавно добавили в web-inf -> lib. например jstl jars.

рахул
источник