XmlベースのSpring MVCアプリをJava設定ベースのアプリに移動しようとしています。Mavenで使用できるさまざまなJava.servletクラスとの不一致があるようです。たとえば、 addServlet()メソッドとそうでないものがあります。
これが私の設定クラスです:
public class MyWebAppInitializer implements WebApplicationInitializer {
@Override
public void onStartup(ServletContext container) throws ServletException {
AnnotationConfigWebApplicationContext rootContext =
new AnnotationConfigWebApplicationContext();
rootContext.register(JpaSandboxConf.class);
ServletRegistration.Dynamic registration = container.addServlet("dispatcher", new DispatcherServlet());
registration.setLoadOnStartup(1);
registration.addMapping("/myapp/*");
}
}
これはかなり物議を醸すようです。を取得するために
container.addServlet()
メソッド、私はこれを私のpomに含めました:
<dependency>
<groupId>org.Apache.Tomcat</groupId>
<artifactId>Tomcat-servlet-api</artifactId>
<version>7.0.30</version>
</dependency>
私はこれを試しましたが、以下のエントリからのServletContextクラスDID NOT WORK(それがaddServlet()メソッドを提供しなかったという点で):
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>com.springsource.javax.servlet</artifactId>
<version>2.5.0</version>
<scope>provided</scope>
</dependency>
私がこれを実行しようとすると
mvn clean Tomcat7:run
残念ながら手に入る
SEVERE: A child container failed during start
Java.util.concurrent.ExecutionException: org.Apache.catalina.LifecycleException: Failed to start component [StandardEngine[Tomcat].StandardHost[localhost].StandardContext[/]]
at Java.util.concurrent.FutureTask$Sync.innerGet(FutureTask.Java:252)
at Java.util.concurrent.FutureTask.get(FutureTask.Java:111)
at org.Apache.catalina.core.ContainerBase.startInternal(ContainerBase.Java:1130)
at org.Apache.catalina.core.StandardHost.startInternal(StandardHost.Java:782)
at org.Apache.catalina.util.LifecycleBase.start(LifecycleBase.Java:150)
at org.Apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.Java:1568)
at org.Apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.Java:1558)
at Java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.Java:334)
at Java.util.concurrent.FutureTask.run(FutureTask.Java:166)
at Java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.Java:1145)
at Java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.Java:615)
at Java.lang.Thread.run(Thread.Java:722)
Caused by: org.Apache.catalina.LifecycleException: Failed to start component [StandardEngine[Tomcat].StandardHost[localhost].StandardContext[/]]
at org.Apache.catalina.util.LifecycleBase.start(LifecycleBase.Java:154)
... 7 more
Caused by: Java.lang.ClassCastException: org.springframework.web.SpringServletContainerInitializer cannot be cast to javax.servlet.ServletContainerInitializer
at org.Apache.catalina.startup.ContextConfig.getServletContainerInitializer(ContextConfig.Java:1543)
at org.Apache.catalina.startup.ContextConfig.processServletContainerInitializers(ContextConfig.Java:1464)
at org.Apache.catalina.startup.ContextConfig.webConfig(ContextConfig.Java:1190)
at org.Apache.catalina.startup.ContextConfig.configureStart(ContextConfig.Java:825)
at org.Apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.Java:300)
at org.Apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.Java:119)
at org.Apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.Java:90)
at org.Apache.catalina.core.StandardContext.startInternal(StandardContext.Java:5161)
at org.Apache.catalina.util.LifecycleBase.start(LifecycleBase.Java:150)
... 7 more
1つのクラスはSpringフレームワークから、もう1つのクラスはjavax.servletから取得されていますが、このメソッドはSpring提供クラスから存在していません(この例はSpring 3.2のドキュメント自体に存在するため、イライラします)。
Spring 3.2を使用しています。私はEclipseを使用していません(すべての例はEclipseベースで、IntelliJを使用しています)。これはMavenプロジェクトです
私はあなたの助けに感謝します。
Pomのより優れたサーブレット3.0 API依存関係エントリは、こちらから入手できます- https://github.com/SpringSource/greenhouse/tree/servlet 、また、スコープをprovided
としてマークする必要がありますそうでない場合、jarは最終的な戦争に含まれ、コンテナによって提供されるjarを妨害します。これは、ケースで起こっているようです。
私は春なしで同様の問題がありました、mvn Tomcat7:run
は、サーブレットがOpenShiftに正常にデプロイされているにもかかわらず、機能しませんでした。 Biju Kunjummenの回答によると、私にとっての問題は、どのservlet-apiをコンパイルするかでした。
壊れた:
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.0.1</version>
<scope>provided</scope>
</dependency>
修繕:
<dependency>
<groupId>org.mortbay.jetty</groupId>
<artifactId>servlet-api</artifactId>
<version>3.0.20100224</version>
<scope>provided</scope>
</dependency>
理由はよくわかりませんが、現在は機能しています。
providedCompile 'javax.servlet:javax.servlet-api:3.1.0'
問題を解決する
Gradle Tomcatプラグインと同じ問題に直面していました。 Tomcatのバージョンを8に更新したところ、問題なく動作しました。
plugins {
id "com.bmuschko.Tomcat" version "2.2.2"
id "Java"
id "Eclipse"
id "idea"
id "war"
}
dependencies {
providedCompile ('javax.servlet:javax.servlet-api:3.1.0')
providedCompile ('javax.servlet.jsp:jsp-api:2.2')
compile ('org.springframework:spring-webmvc:4.2.1.RELEASE')
def tomcatVersion = '8.0.27'
Tomcat "org.Apache.Tomcat.embed:Tomcat-embed-core:${tomcatVersion}",
"org.Apache.Tomcat.embed:Tomcat-embed-logging-juli:${tomcatVersion}",
"org.Apache.Tomcat.embed:Tomcat-embed-jasper:${tomcatVersion}"
}
EclipseでTomcatを使用すると、同じエラーが発生します。
これを解決するには、[サーバー]タブに移動し、Tomcatをダブルクリックして、[発行せずにサービスモジュール]チェックボックスをオフにします。
私もこの問題を抱えていますが、私は彼らの方法を使ってそれを処理しましたが、失敗しました。私が使用したTomcatのバージョンは7と8.0で、この問題も発生しました。 Tomcat 8.5を使用しても問題はありません。プロジェクトは正常に実行されました。