深入分析Spring Boot2,解决 java.lang.ArrayStoreException异常

扫码关注公众号:Java 技术驿站

发送:vip
将链接复制到本浏览器,永久解锁本站全部文章

【公众号:Java 技术驿站】 【加作者微信交流技术,拉技术群】

将某个项目从Spring Boot1升级Spring Boot2之后出现如下报错,查了很多不同的解决方法都没有解决:

Spring boot2项目启动时遇到了异常:

java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy

20191017100371\_1.png

    Caused by: java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy
        at sun.reflect.annotation.AnnotationParser.parseClassArray(AnnotationParser.java:724) ~[na:1.8.0_65]
        at sun.reflect.annotation.AnnotationParser.parseArray(AnnotationParser.java:531) ~[na:1.8.0_65]
        at sun.reflect.annotation.AnnotationParser.parseMemberValue(AnnotationParser.java:355) ~[na:1.8.0_65]
        at sun.reflect.annotation.AnnotationParser.parseAnnotation2(AnnotationParser.java:286) ~[na:1.8.0_65]
        at sun.reflect.annotation.AnnotationParser.parseAnnotations2(AnnotationParser.java:120) ~[na:1.8.0_65]
        at sun.reflect.annotation.AnnotationParser.parseAnnotations(AnnotationParser.java:72) ~[na:1.8.0_65]
        at java.lang.Class.createAnnotationData(Class.java:3521) ~[na:1.8.0_65]
        at java.lang.Class.annotationData(Class.java:3510) ~[na:1.8.0_65]
        at java.lang.Class.createAnnotationData(Class.java:3526) ~[na:1.8.0_65]
        at java.lang.Class.annotationData(Class.java:3510) ~[na:1.8.0_65]
        at java.lang.Class.getAnnotation(Class.java:3415) ~[na:1.8.0_65]
        at java.lang.reflect.AnnotatedElement.isAnnotationPresent(AnnotatedElement.java:258) ~[na:1.8.0_65]
        at java.lang.Class.isAnnotationPresent(Class.java:3425) ~[na:1.8.0_65]
        at org.springframework.core.annotation.AnnotatedElementUtils.hasAnnotation(AnnotatedElementUtils.java:570) ~[spring-core-5.0.9.RELEASE.jar:5.0.9.RELEASE]
        at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping.isHandler(RequestMappingHandlerMapping.java:177) ~[spring-webmvc-5.0.9.RELEASE.jar:5.0.9.RELEASE]
        at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping.initHandlerMethods(AbstractHandlerMethodMapping.java:218) ~[spring-webmvc-5.0.9.RELEASE.jar:5.0.9.RELEASE]
        at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping.afterPropertiesSet(AbstractHandlerMethodMapping.java:189) ~[spring-webmvc-5.0.9.RELEASE.jar:5.0.9.RELEASE]
        at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping.afterPropertiesSet(RequestMappingHandlerMapping.java:136) ~[spring-webmvc-5.0.9.RELEASE.jar:5.0.9.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1758) ~[spring-beans-5.0.9.RELEASE.jar:5.0.9.RELEASE]
        at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1695) ~[spring-beans-5.0.9.RELEASE.jar:5.0.9.RELEASE]
        ... 16 common frames omitted

20191017100371\_2.png

经过简单排查后,怀疑是因为jar版本冲突引起的异常,使用异常断点:

20191017100371\_3.png

20191017100371\_4.png

然后在

20191017100371\_5.png

20191017100371\_6.png

20191017100371\_7.png

应该是从class org.activiti.spring.boot.SecurityAutoConfiguration出错,然后报错java.lang.ArrayStoreException: sun.reflect.annotation.TypeNotPresentExceptionProxy

尝试复现异常:

    SecurityAutoConfiguration securityAutoConfiguration=new SecurityAutoConfiguration();

正常

    SecurityAutoConfiguration.class.getDeclaredAnnotation(Aspect.class);

20191017100371\_8.png

异常复现。

然后找到TypeNotPresentExceptionProxy类,使用Ctrl+N/Ctrl+N+N

20191017100371\_9.png

然后在构造方法中打断点,发现:

20191017100371\_10.png

发现是cause:DefaultAuthenticationEventPublisher找不到引发的报错。

实际报错是ClassNotFound。

仔细看下代码,可以发现AnnotationParser.parseClassValue把异常包装成为Object。

20191017100371\_11.png

        private static Object parseClassValue(ByteBuffer buf,
                                              ConstantPool constPool,
                                              Class<?> container) {
            int classIndex = buf.getShort() & 0xFFFF;
            try {
                try {
                    String sig = constPool.getUTF8At(classIndex);
                    return parseSig(sig, container);
                } catch (IllegalArgumentException ex) {
                    // support obsolete early jsr175 format class files
                    return constPool.getClassAt(classIndex);
                }
            } catch (NoClassDefFoundError e) {
                return new TypeNotPresentExceptionProxy("[unknown]", e);
            }
            catch (TypeNotPresentException e) {
                return new TypeNotPresentExceptionProxy(e.typeName(), e.getCause());
            }
        }

20191017100371\_12.png

然后在sun.reflect.annotation.AnnotationParser.parseClassArray(int, ByteBuffer, ConstantPool, Class<?>)里尝试直接设置到数组里。

而这里数组越界了,ArrayStoreException只有越界的Object的类型信息,也就是上面的。

解决:

1:将springboot2.0降级为原来的1.X版本

2:在springboot启动类上添加

    @SpringBootApplication(exclude = SecurityAutoConfiguration.class)

3:修改源码的集成问题,重新编译

总结:

具体问题还要具体分析,不同的代码引发该问题的原因也不相同。

我的问题是:

springboot2.0不能与activiti6.0.0直接集成使用,因为activiti6.0.0出来的时候springboot2.0还没有出来,activiti6.0.0 支持springboot1.2.6以上,2.0.0以下的版本。

这里实际报错是ClassNotFound。

来源:https://www.cnblogs.com/jiangwz/p/9711998.html

郑州男科医院哪家好

郑州做人流哪家好

郑州人流医院哪家好

郑州最好的人流医院


来源:[]()

赞(0) 打赏
版权归原创作者所有,任何形式的转载请联系博主:daming_90:Java 技术驿站 » 深入分析Spring Boot2,解决 java.lang.ArrayStoreException异常

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏