您的位置:首页 > 编程语言 > Java开发

Maven+Spring framework生成的可执行jar文件执行异常

2015-09-17 15:49 519 查看
参考:http://www.cnblogs.com/lhj588/archive/2012/03/23/2414318.html

注意:验证通过;

环境:

使用maven创建一个java project,利用Spring framework开发一个java程序,使用maven assembly生成一个可执行jar包。

异常:

在使用java -jar test.jar命令执行jar文件时,出现下面几种异常:

1、获取xsd方案文档异常:

log:

15:17:56,797  INFO FileSystemXmlApplicationContext:510 - Refreshing org.springframework.context.support.FileSystemXmlApplicationContext@1f2e95f: startup date [Thu Sep 17 15:17:56 CST 2015]; root of context hierarchy
15:17:56,840  INFO XmlBeanDefinitionReader:317 - Loading XML bean definitions from file [G:\applicationContext.xml]
15:17:58,065  WARN XmlBeanDefinitionReader:48 - Ignored XML validation warningorg.xml.sax.SAXParseException; lineNumber: 11; columnNumber: 114; schema_reference.4: 无法读取方案文档 'http://www.springframework.org/schema/beans/spring-beans-4.1.xsd', 原因为 1) 无法找到文档; 2) 无法读取文档; 3) 文档的根元素不是 <xsd:schema>。


分析:

a) 本地没有该文件;(为什么会没有?这是根源)

b) 而网络不通;(直接原因)

2、

Exception in thread "main" org.springframework.beans.factory.parsing.BeanDefinitionParsingException:

Configuration problem: Unable to locate Spring NamespaceHandler
for XML schema namespace [http://www.springframework.org/schema/context]
at org.springframework.beans.factory.parsing.FailFastProblemReporter.
error(FailFastProblemReporter.java:68)
at org.springframework.beans.factory.parsing.ReaderContext.error(ReaderContext.java:85)
at org.springframework.beans.factory.parsing.ReaderContext.error(ReaderContext.java:80)
at org.springframework.beans.factory.xml.BeanDefinitionParserDelegate.
error(BeanDefinitionParserDelegate.java:284)
at org.springframework.beans.factory.xml.BeanDefinitionParserDelegate.
parseCustomElement(BeanDefinitionParserDelegate.java:1332)
at org.springframework.beans.factory.xml.BeanDefinitionParserDelegate.
parseCustomElement(BeanDefinitionParserDelegate.java:1325)
at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.
parseBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:135)
at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.
registerBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:93)....


原因分析:
用压缩工具打开生成的jar包,发现包中目录/META-INF/中的文件spring.handlers和spring.schemas都为空。

原来是在打包过程中,所有依赖包都会把各自/META-INF/目录下的所有文件拷贝到新jar包中的/META-INF目录下,而有多个依赖包中都有/META-INF/spring.handlers和spring.schemas文件,导致这两个文件被覆盖成空文件。

解决方案:

在拷贝META-INF目录下的文件时,这些重名的文件不允许被覆盖,而应该采用追加的方式进行合并。

操作步骤:

1、在src/main/resources目录下新建META-INF目录;

2、在src/main/resources/META-INF目录下新建文件:MANIFEST.MF,
spring.handlers, spring.schemas;

3、在pom.xml文件中添加如下配置:

注意:com.test.mainClass表示可执行程序的入口,需要根据工程实际进行配置。

4、使用maven assembly工具生成可执行的jar包;

5、执行:java -jar test.jar即可。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: