参考: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文件中添加如下配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>
1.4
</version>
<executions>
<execution>
<phase>
package
</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<transformers>
<transformer
implementation=
"org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"
>
<mainClass> com.test.mainClass </mainClass>
</transformer>
<transformer
implementation=
"org.apache.maven.plugins.shade.resource.AppendingTransformer"
>
<resource>META-INF/spring.handlers</resource>
</transformer>
<transformer
implementation=
"org.apache.maven.plugins.shade.resource.AppendingTransformer"
>
<resource>META-INF/spring.schemas</resource>
</transformer>
</transformers>
<shadedArtifactAttached>
true
</shadedArtifactAttached>
<!-- optional -->
<shadedClassifierName>executable</shadedClassifierName>
</configuration>
</execution>
</executions>
</plugin>
|
注意:com.test.mainClass表示可执行程序的入口,需要根据工程实际进行配置。
4、使用maven assembly工具生成可执行的jar包;
5、执行:java -jar test.jar即可。