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

来源:互联网 发布:linux alias 带参数 编辑:程序博客网 时间:2024/05/16 06:19

参考: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 hierarchy15: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 NamespaceHandlerfor 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即可。










0 1
原创粉丝点击