s2sh框架 启动时错误<java.lang.VerifyError&gt

本文介绍了解决s2sh框架启动时出现java.lang.VerifyError异常的方法。异常由hibernate-core与hibernate-annotations版本冲突引起,通过调整依赖解决了问题。

s2sh框架 启动时异常<java.lang.VerifyError>

????? 最近项目转入maven管理,之前是直接把包放入项目中,而且又不是本人添加。现在需要一一从maven中央库对应下载所需的包,网络又不给力,那是相当的费劲。maven中央库又有着各种版本令人迷惑的各种版本的类似的包,一不小心就搞错了。另外,再加上项目中包的信息又不太全,有就只是一个简单的名字,又的有是从别的项目中copy过来的。种种原因导致在转入maven管理的过程中,项目一直无法正常启动。下面就是其中一个问题的分析及解决,异常信息如下:

org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'addOnDao' defined in file [D:\tomcat-7.0.11\webapps\CATeam\WEB-INF\classes\com\airchina\team\dao\impl\hibernate\AddOnDaoImpl.class]: Unsatisfied dependency expressed through constructor argument with index 0 of type [org.hibernate.SessionFactory]: : Error creating bean with name 'sessionFactory' defined in URL [file:/D:/tomcat-7.0.11/webapps/CATeam/WEB-INF/classes/applicationContext.xml]: Invocation of init method failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [org.hibernate.cfg.AnnotationConfiguration]: Constructor threw exception; nested exception is java.lang.VerifyError: class org.hibernate.type.WrappedMaterializedBlobType overrides final method getReturnedClass.()Ljava/lang/Class;; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in URL [file:/D:/tomcat-7.0.11/webapps/CATeam/WEB-INF/classes/applicationContext.xml]: Invocation of init method failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [org.hibernate.cfg.AnnotationConfiguration]: Constructor threw exception; nested exception is java.lang.VerifyError: class org.hibernate.type.WrappedMaterializedBlobType overrides final method getReturnedClass.()Ljava/lang/Class;at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:730)at org.springframework.beans.factory.support.ConstructorResolver.autowireConstructor(ConstructorResolver.java:196)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireConstructor(AbstractAutowireCapableBeanFactory.java:1003)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:907)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:485)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:293)at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:290)at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:192)at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:585)at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:895)at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:425)at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:282)at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:204)at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:47)at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4681)at org.apache.catalina.core.StandardContext$1.call(StandardContext.java:5184)at org.apache.catalina.core.StandardContext$1.call(StandardContext.java:5179)at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)at java.util.concurrent.FutureTask.run(FutureTask.java:138)at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)at java.lang.Thread.run(Thread.java:662)Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in URL [file:/D:/tomcat-7.0.11/webapps/CATeam/WEB-INF/classes/applicationContext.xml]: Invocation of init method failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [org.hibernate.cfg.AnnotationConfiguration]: Constructor threw exception; nested exception is java.lang.VerifyError: class org.hibernate.type.WrappedMaterializedBlobType overrides final method getReturnedClass.()Ljava/lang/Class;at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1420)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:293)at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:290)at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:192)at org.springframework.beans.factory.support.DefaultListableBeanFactory.findAutowireCandidates(DefaultListableBeanFactory.java:848)at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:790)at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:707)at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:795)at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:723)... 23 moreCaused by: org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [org.hibernate.cfg.AnnotationConfiguration]: Constructor threw exception; nested exception is java.lang.VerifyError: class org.hibernate.type.WrappedMaterializedBlobType overrides final method getReturnedClass.()Ljava/lang/Class;at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:141)at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:104)at org.springframework.orm.hibernate3.LocalSessionFactoryBean.newConfiguration(LocalSessionFactoryBean.java:818)at org.springframework.orm.hibernate3.LocalSessionFactoryBean.buildSessionFactory(LocalSessionFactoryBean.java:549)at org.springframework.orm.hibernate3.AbstractSessionFactoryBean.afterPropertiesSet(AbstractSessionFactoryBean.java:211)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1477)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1417)... 34 moreCaused by: java.lang.VerifyError: class org.hibernate.type.WrappedMaterializedBlobType overrides final method getReturnedClass.()Ljava/lang/Class;at java.lang.ClassLoader.defineClass1(Native Method)at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)at java.lang.ClassLoader.defineClass(ClassLoader.java:615)at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2818)at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1148)at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1643)at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1521)at org.hibernate.type.BasicTypeRegistry.<init>(BasicTypeRegis2012-11-15 20:30:53 org.apache.catalina.core.StandardContext listenerStart严重: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListenerorg.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'addOnDao' defined in file [D:\tomcat-7.0.11\webapps\CATeam\WEB-INF\classes\com\airchina\team\dao\impl\hibernate\AddOnDaoImpl.class]: Unsatisfied dependency expressed through constructor argument with index 0 of type [org.hibernate.SessionFactory]: : Error creating bean with name 'sessionFactory' defined in URL [file:/D:/tomcat-7.0.11/webapps/CATeam/WEB-INF/classes/applicationContext.xml]: Invocation of init method failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [org.hibernate.cfg.AnnotationConfiguration]: Constructor threw exception; nested exception is java.lang.VerifyError: class org.hibernate.type.WrappedMaterializedBlobType overrides final method getReturnedClass.()Ljava/lang/Class;; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in URL [file:/D:/tomcat-7.0.11/webapps/CATeam/WEB-INF/classes/applicationContext.xml]: Invocation of init method failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [org.hibernate.cfg.AnnotationConfiguration]: Constructor threw exception; nested exception is java.lang.VerifyError: class org.hibernate.type.WrappedMaterializedBlobType overrides final method getReturnedClass.()Ljava/lang/Class;at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:730)at org.springframework.beans.factory.support.ConstructorResolver.autowireConstructor(ConstructorResolver.java:196)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireConstructor(AbstractAutowireCapableBeanFactory.java:1003)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:907)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:485)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:293)at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:290)at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:192)at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:585)at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:895)at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:425)at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:282)at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:204)at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:47)at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4681)at org.apache.catalina.core.StandardContext$1.call(StandardContext.java:5184)at org.apache.catalina.core.StandardContext$1.call(StandardContext.java:5179)at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)at java.util.concurrent.FutureTask.run(FutureTask.java:138)at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)at java.lang.Thread.run(Thread.java:662)Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in URL [file:/D:/tomcat-7.0.11/webapps/CATeam/WEB-INF/classes/applicationContext.xml]: Invocation of init method failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [org.hibernate.cfg.AnnotationConfiguration]: Constructor threw exception; nested exception is java.lang.VerifyError: class org.hibernate.type.WrappedMaterializedBlobType overrides final method getReturnedClass.()Ljava/lang/Class;at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1420)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:456)at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:293)at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222)at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:290)at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:192)at org.springframework.beans.factory.support.DefaultListableBeanFactory.findAutowireCandidates(DefaultListableBeanFactory.java:848)at org.springframework.beans.factory.support.DefaultListableBeanFactory.doResolveDependency(DefaultListableBeanFactory.java:790)at org.springframework.beans.factory.support.DefaultListableBeanFactory.resolveDependency(DefaultListableBeanFactory.java:707)at org.springframework.beans.factory.support.ConstructorResolver.resolveAutowiredArgument(ConstructorResolver.java:795)at org.springframework.beans.factory.support.ConstructorResolver.createArgumentArray(ConstructorResolver.java:723)... 23 moreCaused by: org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [org.hibernate.cfg.AnnotationConfiguration]: Constructor threw exception; nested exception is java.lang.VerifyError: class org.hibernate.type.WrappedMaterializedBlobType overrides final method getReturnedClass.()Ljava/lang/Class;at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:141)at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:104)at org.springframework.orm.hibernate3.LocalSessionFactoryBean.newConfiguration(LocalSessionFactoryBean.java:818)at org.springframework.orm.hibernate3.LocalSessionFactoryBean.buildSessionFactory(LocalSessionFactoryBean.java:549)at org.springframework.orm.hibernate3.AbstractSessionFactoryBean.afterPropertiesSet(AbstractSessionFactoryBean.java:211)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1477)at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1417)... 34 moreCaused by: java.lang.VerifyError: class org.hibernate.type.WrappedMaterializedBlobType overrides final method getReturnedClass.()Ljava/lang/Class;at java.lang.ClassLoader.defineClass1(Native Method)at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)at java.lang.ClassLoader.defineClass(ClassLoader.java:615)at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)at org.apache.catalina.loader.WebappClassLoader.findClassInternal(WebappClassLoader.java:2818)at org.apache.catalina.loader.WebappClassLoader.findClass(WebappClassLoader.java:1148)at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1643)at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1521)at org.hibernate.type.BasicTypeRegistry.<init>(BasicTypeRegistry.java:91)at org.hibernate.type.TypeResolver.<init>(TypeResolver.java:59)at org.hibernate.cfg.Configuration.<init>(Configuration.java:250)at org.hibernate.cfg.Configuration.<init>(Configuration.java:302)at org.hibernate.cfg.AnnotationConfiguration.<init>(AnnotationConfiguration.java:168)at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)at java.lang.reflect.Constructor.newInstance(Constructor.java:513)at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:126)... 40 moretry.java:91)at org.hibernate.type.TypeResolver.<init>(TypeResolver.java:59)at org.hibernate.cfg.Configuration.<init>(Configuration.java:250)at org.hibernate.cfg.Configuration.<init>(Configuration.java:302)at org.hibernate.cfg.AnnotationConfiguration.<init>(AnnotationConfiguration.java:168)at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)at java.lang.reflect.Constructor.newInstance(Constructor.java:513)at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:126)... 40 more

?经过多方查找、尝试,最终找到引起此异常的原因:

(1)原项目中hibernate3.jar,这个包的版本信息不明确,在pom文件中引入了hibernate-core-3.6.10.Final.jar。

(2)原项目中hibernate-annotation.jar,版本信息同样不明确,在pom文件中引入了hibernate-annotations-3.5.6-Final.jar。

(3)分析:从?hibernate-core 3.6.0以后hibernate-annotations 被整合到到hibernate-core这个包中,之所以抛出异常就是因为hibernate-core-3.6.10.Final.jar和hibernate-annotations-3.5.6-Final.jar冲突造成的。

(4)解决方法:从pom文件中移除hibernate-annotations-3.5.6-Final.jar依赖即可解决。

?


http://www.reader8.cn/jiaocheng/20130911/1280212.html

### Java.lang.VerifyError 错误的引起原因及解决方案 Java.lang.VerifyError 是一种在类加载阶段发生的错误,表示 JVM 在验证已加载类的字节码时发现不符合规范的问题。以下是该错误的主要引起原因及解决方案: #### 1. **版本不兼容** 如果项目中使用的类库或框架升级后,某些类文件的字节码格式或方法签名发生了变化,而与之相关的类没有重新编译,则可能导致 VerifyError[^3]。例如,一个类依赖于另一个类的方法签名,但后者被修改或删除后未重新编译。 **解决方案**: - 确保所有相关类都使用相同的编译器版本进行重新编译。 - 检查项目中是否存在多个版本的相同库,避免版本冲突。 #### 2. **类文件损坏** 在类文件的传输或存储过程中,如果文件被意外修改或损坏,JVM 在加载该类时可能会抛出 VerifyError。这种情况通常发生在网络传输、存储介质故障或压缩解压操作中。 **解决方案**: - 检查并替换可能损坏的类文件。 - 使用校验工具(如 MD5 或 SHA-1)验证文件完整性。 #### 3. **类加载器问题** 如果项目中使用了自定义的类加载器,并且该类加载器没有正确处理类文件的加载逻辑,也可能导致 VerifyError[^3]。例如,类加载器未能正确解析字节码或加载顺序错误。 **解决方案**: - 检查自定义类加载器的实现,确保其遵循 JVM 规范。 - 避免在类加载器中进行不必要的修改或优化。 #### 4. **安全限制** 有时,JVM 的安全管理器可能会阻止某些类的加载,这也会导致 VerifyError[^3]。例如,某些类可能违反了 JVM 的安全策略或权限设置。 **解决方案**: - 检查项目的安全策略配置,确保所有类都能正常加载。 - 如果需要,调整安全管理器的权限设置。 #### 5. **Dalvik/ART 虚拟机兼容性问题** 在 Android 开发中,不同版本的虚拟机(Dalvik 或 ART)对字节码的支持可能存在差异。例如,Android 5.0 以下的设备可能无法正确解析某些新版本的字节码[^1]。 **解决方案**: - 确保项目的目标 SDK 和最低支持 SDK 设置合理。 - 使用 ProGuard 或 R8 工具优化和兼容化字节码。 ### 示例代码 以下是一个可能导致 VerifyError 的场景及修复示例: #### 错误代码 ```java // 假设 ClassA 的方法签名在升级后发生变化 public class ClassA { public void doSomething() { System.out.println("Doing something..."); } } public class ClassB { public void callClassA() { ClassA classA = new ClassA(); // 方法签名不匹配 classA.doSomethingNew(); } } ``` #### 修复代码 ```java // 确保 ClassB 使用正确的签名调用 public class ClassB { public void callClassA() { ClassA classA = new ClassA(); classA.doSomething(); // 使用正确的签名 } } ``` ### 注意事项 - 在 Android 项目中,建议启用 ProGuard 或 R8 工具以优化字节码并解决兼容性问题[^1]。 - 使用调试工具(如 Logcat 或 IDE 调试器)定位具体的类加载错误信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值