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 ,發生了沖突。