java.lang.LinkageError: javax.servlet.jsp.JspApplicationContext.getExpressionFactory
Когда я пытаюсь запустить свое веб-приложение на Tomcat 7, я получаю следующее исключение:
exception
javax.servlet.ServletException: java.lang.LinkageError: loader constraint violation: when resolving interface method "javax.servlet.jsp.JspApplicationContext.getExpressionFactory()Ljavax/el/ExpressionFactory;
" the class loader (instance of org/apache/jasper/servlet/JasperLoader) of the current class, org/apache/jsp/index_jsp, and the class loader (instance of org/apache/catalina/loader/StandardClassLoader) for resolved class, javax/servlet/jsp/JspApplicationContext,
have different Class objects for the type javax/el/ExpressionFactory used in the signature
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:343)
javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
root cause
java.lang.LinkageError: loader constraint violation: when resolving interface method "javax.servlet.jsp.JspApplicationContext.getExpressionFactory()Ljavax/el/ExpressionFactory;" the class loader (instance of org/apache/jasper/servlet/JasperLoader) of the current class, org/apache/jsp/index_jsp, and the class loader (instance of org/apache/catalina/loader/StandardClassLoader) for resolved class, javax/servlet/jsp/JspApplicationContext, have different Class objects for the type javax/el/ExpressionFactory used in the signature
org.apache.jsp.index_jsp._jspInit(index_jsp.java:31)
org.apache.jasper.runtime.HttpJspBase.init(HttpJspBase.java:49)
org.apache.jasper.servlet.JspServletWrapper.getServlet(JspServletWrapper.java:180)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:369)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:390)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334)
javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
Кажется, что существует конфликт между двумя .jar
библиотеки, но я не знаю, кто они. Как я могу их выяснить и решить?
5 ответов
Это произойдет, когда вы включите в сервер специфичные для сервера библиотеки другой марки / версии сервера. /WEB-INF/lib
вашего веб-приложения, такого как jsp-api.jar
, el-api.jar
, servlet-api.jar
и т. д. Вы должны удалить их все. /WEB-INF/lib
не должен содержать каких-либо специфичных для сервера библиотек. Они принадлежат конкретному серверу (у Tomcat они есть в /lib
папка уже).
Это, кстати, довольно распространенная ошибка новичка, когда они сталкиваются с ошибками компиляции в JSP/Servlet API в своем проекте IDE. Это должно было быть решено по-другому, а именно путем интеграции сервера в IDE и добавления сервера в качестве "целевого времени выполнения" в проект.
Смотрите также:
У вас есть два варианта для добавления в ваши проекты библиотеки, такие как jsp-api.jar
, el-api.jar
, servlet-api.jar
, так далее:
- Добавьте эти библиотеки в качестве внешних jar в вашем
Java Build Path
; - Добавьте их как зависимости maven, установив
provided
область действия для каждого из них, например:
<dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.1</version> <scope>provided</scope> </dependency>
Я застрял с этой ошибкой в течение очень долгого времени, и эта тема сэкономила немало моего времени. Добавив некоторые исследования, которые я сделал, прежде чем решить эту проблему. Да, нам нужно удалить библиотеки, такие как jsp-api.jar, el-api.jar, servlet-api.jar
от /WEB-INF/lib
папка. Но как?
В моем случае я использую Apache Ivy в качестве менеджера зависимостей и использую Spring MVC. Он загружает все зависимости вместе с библиотеками, упомянутыми выше. Во время выполнения эти конфликты с API, предоставляемыми библиотеками Tomcat. Простым решением было бы исключить эти jar-файлы из зависимостей или создать конфигурации и включить эти библиотеки только в конфигурацию времени компиляции. Что сработало для меня быстро, так это исключение этих библиотек.
<dependency org="org.springframework" name="spring-webmvc"
rev="4.0.4.RELEASE">
<exclude org="javax.servlet" name="javax.servlet-api" />
<exclude org="javax.servlet.jsp" name="jsp-api" />
<exclude org="javax.el" name="javax.el-api" />
</dependency>
Проверьте эту страницу
http://www.jarfinder.com/index.php/java/info/org.apache.jasper.runtime.HttpJspBase
Найдите, какие банки вы использовали в этом. Удалите одного, если найдете два.:)
В моем случае у меня была зависимость tomcat, а также плагин tomcat, упомянутый в POM. Удалил зависимость, оставив там только плагин, и все заработало.
Это странная ОШИБКА, которую я когда-либо получал
После повторного поиска я нашел это Причины и решение
Я использую Spring, поэтому в моих библиотеках @spring у меня уже есть банка
Servlet-api.jar
или же javax-servlet-api.jar
jsp-api.jar
или же javax-servlet-jsp.jar
Но это не совместимо с моим сервером TOMCAT. Итак, я просто удаляю эти два jar-файла из моего встроенного пути и сборки развертывания. Теперь я перехожу к моему "E:\Locker\Software\apache-tomcat-6.0.44\lib", где находится мой сервер Tomcat. и добавить эти две банки в мой проект
servlet-api.jar
jsp-api.jar