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

21 篇文章 0 订阅
16 篇文章 0 订阅

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










  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值