activiti7 + springboot2 (十五) JSP页面使用EL表达式引起的错误解决
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 ,发生了冲突。