在JBoss上使用Spring MVC Java Config时出现404错误

时间:2014-11-05 07:54:50

标签: spring-mvc jboss spring-java-config

我用Java Config编写了一个小的Spring MVC应用程序。它在Tomcat上工作得很好,但在JBoss EAP 6.2上却没有。它在JBoss上成功部署,但是当我请求Spring MVC定义的任何页面和浏览器中的404错误时,我收到此警告。

WARN [org.springframework.web.servlet.PageNotFound] (http-/127.0.0.1:8080-1) No mapping found for HTTP request with URI [/example-web/pages/login.jsp] in DispatcherServlet with name 'dispatcher'

在这里你可以看到我的代码:

public class WebApplicationInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {

@Override
protected Class<?>[] getRootConfigClasses() {
    return new Class[] { RootConfiguration.class};
}

@Override
protected Class<?>[] getServletConfigClasses() {
    return new Class[] { WebMvcConfig.class };
}

@Override
protected String[] getServletMappings() {
    return new String[] { "/*" };
}

@Override
protected Filter[] getServletFilters() {
    return new Filter[] { new HiddenHttpMethodFilter() };
}
}

这是我的Spring MVC配置:

@EnableWebMvc
@ComponentScan("com.spring.example.w.controller")
@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {

    @Override
    public void addViewControllers(ViewControllerRegistry registry) {
        registry.addViewController("login").setViewName("login");
        registry.setOrder(Ordered.HIGHEST_PRECEDENCE);
    }

    @Bean
    public InternalResourceViewResolver getInternalResourceViewResolver(){
        InternalResourceViewResolver resolver = new InternalResourceViewResolver();
        resolver.setPrefix("/pages/");
        resolver.setSuffix(".jsp");
        return resolver;
    }
}

和RootConfig:

@Configuration
@ComponentScan
public class RootConfiguration {
}

在部署期间,我可以在日志中看到请求已映射到:

INFO  [org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping] (ServerService Thread Pool -- 71) Mapped "{[/start],methods=[GET],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public org.springframework.web.servlet.ModelAndView com.spring.example.w.controller.StartController.handleStart() throws javax.servlet.ServletException,java.io.IOException
INFO  [org.springframework.web.servlet.handler.SimpleUrlHandlerMapping] (ServerService Thread Pool -- 71) Mapped URL path [/login] onto handler of type [class org.springframework.web.servlet.mvc.ParameterizableViewController]
INFO  [org.springframework.web.context.ContextLoader] (ServerService Thread Pool -- 71) Root WebApplicationContext: initialization completed in 2530 ms
INFO  [org.apache.catalina.core.ContainerBase.[jboss.web].[default-host].[/example-web]] (ServerService Thread Pool -- 71) Initializing Spring FrameworkServlet 'dispatcher'
INFO  [org.springframework.web.servlet.DispatcherServlet] (ServerService Thread Pool -- 71) FrameworkServlet 'dispatcher': initialization started

有关我为何会收到404错误的任何帮助,我们非常感谢此警告。我应该再一次强调它正在使用Tomcat。提前谢谢。

2 个答案:

答案 0 :(得分:0)

正在阅读SivaLabs的教程,在JBoss上运行应用程序时出现这样的问题,可以正常使用tomcat。通过将DispatcherServlet映射更改为&#34; / app / *&#34;来解决问题。 。您也可以尝试实现WebApplicationInitializer而不是使用抽象类。这是一个例子:

 @Override
    public void onStartup(ServletContext servletContext) throws ServletException {
        WebApplicationContext context = getContext();
        servletContext.addListener(new ContextLoaderListener(context));
        ServletRegistration.Dynamic dispatcher = servletContext.addServlet("DispatcherServlet", new DispatcherServlet(context));
        dispatcher.setLoadOnStartup(1);
        dispatcher.addMapping("/"); // i have a more or less big website, and can't see advantages by using "/*" mapping, this can be also a problem. 
    }

    private AnnotationConfigWebApplicationContext getContext() {
        AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();
        context.setConfigLocations("ua.company.config.WebConfig", "ua.company.config.PersistenceConfig", "ua.company.config.SecurityConfig");
        return context;
    }

答案 1 :(得分:0)

您可能遇到Red Hat bug 1094248,“没有web.xml不能覆盖默认servlet”。此问题显然会影响EAP 6.2、6.3和6.4.0。来自错误报告:

  

将Spring调度程序servlet映射到url模式“ /”不起作用   以编程方式换句话说,覆盖默认的servlet不是   Java代码可以实现。

     

结果:许多用户将Spring的DispatcherServlet映射到'/',并且   在web.xml中完成此操作时效果很好。但是当这种配置   以编程方式完成,默认servlet首先绑定到“ /”。这个   防止以后绑定DispatcherServlet。弹簧控制器不是   映射并检索404。

     

解决方法(如果有):使用web.xml配置或地图调度程序   servlet以编程方式更改为某些特定的URL模式。例如   “ / dispatcher / *”

对于EAP 6.4,此问题已在6.4.1版中修复。我不知道EAP的早期版本。该错误已于2017年1月修复,因此您需要查找此后发布的补丁。

有权访问Red Hat解决方案知识库的人们可能还想看看solution 1211203