#java #eclipse #maven #eclipse-wtp
#java #eclipse #maven #eclipse-wtp
Вопрос:
Я получаю ClassCastException для org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
В журналах я вижу, что мой javax.servlet.Filter
загружается дважды.
Один раз из моего локального репозитория maven
[Loaded javax.servlet.Filter from file:/C:/Users/xxxx/.m2/repository/javax/servlet/servlet-api/2.5/servlet-api-2.5.jar]
И еще один от tomcat
[Loaded javax.servlet.Filter from file:/C:/Apache.org/apache-tomcat-6.0.32/lib/servlet-api.jar]
Как только загружается вторая версия filter, я получаю следующее исключение в журнале сервера.
Apr 20, 2011 2:42:21 PM org.apache.catalina.core.StandardContext filterStart
SEVERE: Exception starting filter struts2
java.lang.ClassCastException: org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter cannot be cast to javax.servlet.Filter
at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:275)
at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:422)
at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:115)
at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4071)
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4725)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:799)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:779)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:601)
at org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:675)
at org.apache.catalina.startup.HostConfig.deployDescriptors(HostConfig.java:601)
at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:502)
at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1315)
at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:324)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:142)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1061)
at org.apache.catalina.core.StandardHost.start(StandardHost.java:840)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:463)
at org.apache.catalina.core.StandardService.start(StandardService.java:525)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:754)
at org.apache.catalina.startup.Catalina.start(Catalina.java:595)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
Apr 20, 2011 2:42:21 PM org.apache.catalina.core.StandardContext start
SEVERE: Error filterStart
Вот фрагмент моего pom.xml
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<type>jar</type>
<scope>provided</scope>
<optional>false</optional>
</dependency>
Спасибо, что посмотрели.
Комментарии:
1. Можете ли вы опубликовать свой pom.xml пожалуйста
Ответ №1:
Вы должны отметить зависимость servlet-api в своем pom.xml <scope>provided</scope>
поэтому maven не включит его в окончательную сборку. Затем выполните mvn clean package
Комментарии:
1. @fmucar Я вижу область, как указано. Есть еще идеи?
2. помещает ли он servlet-api в вашу окончательную сборку в web-inf / lib? возможно, дочерний pom переопределяет его
3. В моем web-inf / lib ничего нет, но я вижу jar servlet-api в моем tomcat / lib
4. опубликуйте свой pom-файл. у tomcat / lib обычно есть servlet-api, так что это довольно нормально. И расскажите нам, как вы развертываете свое приложение. Вы развертываете файл war?
5. Я отредактировал свой пост, чтобы поместить фрагмент pom. Я просмотрел рабочее пространство, чтобы убедиться, что у меня нет другого pom.xml это устраняет зависимость servlet-api. Кроме того, я не развертываю файл war в своем локальном окне. Я запускаю eclipse с включенным EE, поэтому я настроил его на обслуживание модулей без публикации.
Ответ №2:
Пытаюсь очистить все взорванные войны из вашего временного каталога tomcat. Иногда этот мусор приводит к загрузке нескольких версий класса. Особенно, если вы изменили свой pom.xml в промежуточный период. Сделайте это и оставьте область как provided