0

私の初期化クラス

public class HomeServlet extends 
AbstractAnnotationConfigDispatcherServletInitializer{

@Override
protected Class<?>[] getRootConfigClasses() {

    return null;
}

@Override
protected Class<?>[] getServletConfigClasses() {

    return new Class<?>[]{SpringContextConfig1.class};
}

@Override
protected String[] getServletMappings() {

    return new String[] {"/home"};
}

}

構成クラス

@ComponentScan(basePackages={"spittr.controllers"})
@Configuration
@EnableWebMvc
public class SpringContextConfig1 extends WebMvcConfigurerAdapter{

@Bean
public ViewResolver getViewResolver(){
    InternalResourceViewResolver ivr=new InternalResourceViewResolver();
    ivr.setPrefix("/WEB-INF/jsp/");
    ivr.setSuffix(".jsp");
    ivr.setExposeContextBeansAsAttributes(true);
    return ivr;
}

}

コントローラ

@Controller
public class HomeController {


@RequestMapping(value="/home",method=RequestMethod.GET)
public String home(){
    return "home";
}

}

これは非常に単純なプログラムで、Spring MVC の JavaConfig をテストするために作成しました。「Spring in Action」ブックのすべての手順を正確に実行しました。

このコードを実行すると、このエラーが発生します

09:41:37,854 ERROR [org.jboss.msc.service.fail] (ServerService Thread Pool -- 72) MSC000001: サービス jboss.undertow.deployment.default-server.default-host./spittr: org の開始に失敗しました。 jboss.msc.service.StartException サービス jboss.undertow.deployment.default-server.default-host./spittr: java.lang.RuntimeException: java.lang.IllegalArgumentException: Failed to register servlet with name 'dispatcher'.Check if同じ名前で登録された別のサーブレットがあります。org.wildfly.extension.undertow.deployment.UndertowDeploymentService$1.run(UndertowDeploymentService.java:85) で java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) で java.util.concurrent.FutureTask. java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) で (FutureTask.java:266) を実行します。org.jboss.threads.JBossThread.run(JBossThread.java:320) で java.lang.Thread.run(Thread.java:745) で concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 原因: java .lang.RuntimeException: java.lang.IllegalArgumentException: 'dispatcher' という名前のサーブレットを登録できませんでした。同じ名前で登録されている別のサーブレットがあるかどうかを確認してください。io.undertow.servlet.core.DeploymentManagerImpl.deploy(DeploymentManagerImpl.java:236) で org.wildfly.extension.undertow.deployment.UndertowDeploymentService.startContext(UndertowDeploymentService.java:100) で org.wildfly.extension.undertow.deployment で.UndertowDeploymentService$1.run(UndertowDeploymentService.java:82) ... 6 つ以上 原因: java.lang.IllegalArgumentException: 'dispatcher' という名前のサーブレットを登録できませんでした。同名のサーブレットが他に登録されていないか確認してください。org.springframework.util.Assert.notNull(Assert.java:115) で org.springframework.web.servlet.support.AbstractDispatcherServletInitializer.registerDispatcherServlet(AbstractDispatcherServletInitializer.java:98) で org.springframework.web.servlet.support.AbstractDispatcherServletInitializer .onStartup(AbstractDispatcherServletInitializer.java:71) org.springframework.web.SpringServletContainerInitializer.onStartup(SpringServletContainerInitializer.java:169) で io.undertow.servlet.core.DeploymentManagerImpl$1.call(DeploymentManagerImpl.java:186) で io.undertow .servlet.core.DeploymentManagerImpl$1.call(DeploymentManagerImpl.java:171) at io.undertow.servlet.core.ServletRequestContextThreadSetupAction$1.

エラーのハイライトは、「'dispatcher' という名前のサーブレットを登録できませんでした。同じ名前で別のサーブレットが登録されているかどうかを確認してください。org.wildfly.extension.undertow.deployment.UndertowDeploymentService$1.run(UndertowDeploymentService.java: 85)

この問題を解決するのを手伝ってください。EclipseでWildFly-10を使用しています。

4

2 に答える 2

0

私の友人も同じ問題に遭遇しました。問題は、クラスに正しいパッケージ名が設定されていなかったことです。AAAそして、パッケージ化する前にプロジェクトをきれいにしてください!!!

ここにGitHubのコードがあります

于 2018-05-19T02:21:31.613 に答える