此问题的解决网上有编文章可参考:
http://shangdixinxi.com/detail-1302327.html
以下是摘抄自此文章:
前因:
activiti7整合springboot2,启动服务访问有EL表达式的页面报错 java.lang.NoSuchMethodError: javax.el.ExpressionFactory.getStreamELResolver()Ljavax/el/ELResolver;
解决:
错误提示javax.el.ExpressionFactory没有getStreamELResolver方法,一般根据经验这应该是包冲突。
发现tomcat的tomcat-embed-el包javax.el.ExpressionFactory有getStreamELResolver方法,说明在编译的时候用到的不是这个包,可能是和Activiti7的EL的实现juel包有冲突。
我们首先排除juel的依赖
<dependency> <groupId>org.activiti</groupId> <artifactId>activiti-spring-boot-starter</artifactId> <exclusions> <exclusion> <groupId>de.odysseus.juel</groupId> <artifactId>juel-api</artifactId> </exclusion> <exclusion> <groupId>de.odysseus.juel</groupId> <artifactId>juel-spi</artifactId> </exclusion> </exclusions> </dependency>
重新运行还是报错,错误如下:
java.lang.ClassNotFoundException: com.sun.el.ExpressionFactoryImpl at org.springframework.boot.web.embedded.tomcat.TomcatEmbeddedWebappClassLoader.loadClass(TomcatEmbeddedWebappClassLoader.java:70) ~[spring-boot-2.1.3.RELEASE.jar:2.1.3.RELEASE] at org.apache.catalina.loader.WebappClassLoaderBase.loadClass(WebappClassLoaderBase.java:1186) ~[tomcat-embed-core-9.0.16.jar:9.0.16] at javax.el.FactoryFinder.newInstance(FactoryFinder.java:83) ~[el-api-2.2.jar:na] at javax.el.FactoryFinder.find(FactoryFinder.java:193) ~[el-api-2.2.jar:na] at javax.el.ExpressionFactory.newInstance(ExpressionFactory.java:185) ~[el-api-2.2.jar:na] at javax.el.ExpressionFactory.newInstance(ExpressionFactory.java:156) ~[el-api-2.2.jar:na]
javax.el.ExpressionFactory.newInstance 实例化失败,找不到实现类com.sun.el.ExpressionFactoryImpl
那么我们引入el-api的实现
<dependency> <groupId>org.glassfish.web</groupId> <artifactId>el-impl</artifactId> <version>2.2</version> </dependency>
重新运行,问题解决。
EL是jsp的标准之一,但是从JSP2.1开始,EL Api从javax.el包中分离了出来,删除了对JSP相关类的依赖,这样就可以在Non-JSP环境中使用了。Activiti中的变量就是使用的EL表达式,javax.el.ExpressionFactory在tomcat的EL调用的是tomcat的org.apache.el.ExpressionFactoryImpl,而在Activiti7中的juel调用的是 de.odysseus.el.ExpressionFactoryImpl ,发生了冲突。
我的实际情况:
按上面操作后在eclipse中启动访问页面不报错,然而打成war包后单独启动又会报上述错误,并且是有时候又不报错,感觉还是引入的jar包有冲突,由于类加载顺序的问题,导致有时加载了正确的jar就不报。
最终解决方案:
<dependency>
<groupId>org.glassfish.web</groupId>
<artifactId>el-impl</artifactId>
<version>2.2</version>
<exclusions>
<exclusion>
<groupId>javax.el</groupId>
<artifactId>el-api</artifactId>
</exclusion>
</exclusions>
</dependency>
引入el-impl时会把el-api的jar也附带引入了,而这个包就与tomcat-embed-el包javax.el.ExpressionFactory有冲突,排除掉后整个世界安静了!