Затмение и JSP:java.lang.NoSuchMethodError:javax.servlet.jsp.tagext.TagAttributeInfo.<init>(Ljava/lang/String;ZLjava/lang/String;ZZ)V
-
03-07-2019 - |
Вопрос
Я использую Eclipse 3.4 с WTP 3.0.2 и запускаю довольно большой динамический веб-проект.Я настроил проект так, чтобы иметь к нему доступ по адресу http://127.0.0.1:8080/доля/ но всякий раз, когда я это делаю, я получаю следующую ошибку:
java.lang.NoSuchMethodError: javax.servlet.jsp.tagext.TagAttributeInfo.(Ljava/lang/String;ZLjava/lang/String;ZZ)V at org.apache.jasper.compiler.TagLibraryInfoImpl.createAttribute(TagLibraryInfoImpl.java:572) at org.apache.jasper.compiler.TagLibraryInfoImpl.createTagInfo(TagLibraryInfoImpl.java:401) at org.apache.jasper.compiler.TagLibraryInfoImpl.parseTLD(TagLibraryInfoImpl.java:248) at org.apache.jasper.compiler.TagLibraryInfoImpl.(TagLibraryInfoImpl.java:162) at org.apache.jasper.compiler.Parser.parseTaglibDirective(Parser.java:423) at org.apache.jasper.compiler.Parser.parseDirective(Parser.java:492) at org.apache.jasper.compiler.Parser.parseElements(Parser.java:1552) at org.apache.jasper.compiler.Parser.parse(Parser.java:126) at org.apache.jasper.compiler.ParserController.doParse(ParserController.java:211) at org.apache.jasper.compiler.ParserController.parse(ParserController.java:100) at org.apache.jasper.compiler.Compiler.generateJava(Compiler.java:155) at org.apache.jasper.compiler.Compiler.compile(Compiler.java:295) at org.apache.jasper.compiler.Compiler.compile(Compiler.java:276) at org.apache.jasper.compiler.Compiler.compile(Compiler.java:264) at org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:563) at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:303) at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:314) at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:264) at javax.servlet.http.HttpServlet.service(HttpServlet.java:853) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:269) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:188) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:213) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:172) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:117) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:108) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:174) at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:875) at org.apache.coyote.http11.Http11BaseProtocol$Http11ConnectionHandler.processConnection(Http11BaseProtocol.java:665) at org.apache.tomcat.util.net.PoolTcpEndpoint.processSocket(PoolTcpEndpoint.java:528) at org.apache.tomcat.util.net.LeaderFollowerWorkerThread.runIt(LeaderFollowerWorkerThread.java:81) at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:689) at java.lang.Thread.run(Unknown Source)
Поскольку ни один из вышеперечисленных файлов не является моим собственным, указать причину проблемы довольно сложно.Есть идеи, с чего начать поиск?
Решение
В итоге я ответил на свой вопрос:проблема заключалась в том, что среди необходимых JAR-файлов, которые я добавил в Tomcat, был конфликтующий файл servlet.jar.Когда я удалил это, ошибка исчезла.
Другие советы
Вы установили путь Tomcat в «Настройки->Tomcat->Дополнительно->База Tomcat»?
Попробуйте очистить этот путь (возвратившись к конфигурации по умолчанию) и проверьте, решит ли это проблему.
скорее всего, плагин tomcat в затмении вызывает проблему конфликта. Мне удается решить проблему, получив тот же файл jar той же версии и переопределив его в плагине tomcat в затмении.
У меня была похожая проблема, и я решил эту проблему, проверив, что у меня правильная версия. сервлет.jar в пути к классам, который используется моим приложением, а также я сохранил старый J2EE.jar файл в пути к классам, и это вызывало основную проблему.Поэтому я удалил его из пути к классам, чтобы гарантировать, что он использует файлы по умолчанию.
У меня была та же проблема с запуском Eclipse Helios, с зависимостями обработки Maven и использованием Jetty в качестве веб-сервера.После обновления до Spring 3.1 у меня внезапно возникла эта проблема, но только на моей локальной машине разработки.
Сначала я удалил папки Spring и Jetty в своем локальном репозитории maven и обновил зависимости, но это не улучшило ситуацию.
Затем я просто удалил папки servlet-api и servlet-api-2.5, поставляемые с Jetty (но оставив все остальное), и все заработало.
Приветствуем магию пути к классам.