SpringMvc4.2.5 零配置出现 No mapping found for HTTP request with URI

采用 spring 零配置,参考 http://hanqunfeng.iteye.com/blog/2113820,WebInitializer 类代码如下:

public class WebInitializer implements WebApplicationInitializer {

    private static final Logger logger = LogManager.getLogger(WebInitializer.class);

    @Override
    public void onStartup(ServletContext servletContext) throws ServletException {

        logger.info("-------->启动web应用");

        /*
         *  Log4jConfigListener: log4j 2日志配置,配置文件为 classpath:log4j2.xml
         */
        servletContext.addListener(new Log4jServletContextListener()); 

        Log4jServletFilter log4jServletFilter = new Log4jServletFilter();
        servletContext.addFilter("log4jServletFilter", log4jServletFilter);

        /*
         *  OpenSessionInViewFilter: 加上该 filter 可以保证jackson能够序列化LAZY FetchType
         */
        OpenSessionInViewFilter openSessionInViewFilter = new OpenSessionInViewFilter();  
        FilterRegistration.Dynamic openSessionInViewFilterRegistration = servletContext
                .addFilter("openSessionInViewFilter", openSessionInViewFilter);
        //指定在spring配置的sessionFactory
        openSessionInViewFilterRegistration.setInitParameter("sessionFactoryBeanName", "sessionFactory");
        //singleSession默认为true,若设为false则等于没用OpenSessionInView
        openSessionInViewFilterRegistration.setInitParameter("singleSession", "true");
        openSessionInViewFilterRegistration.addMappingForUrlPatterns(  
                EnumSet.of(DispatcherType.REQUEST, DispatcherType.FORWARD, DispatcherType.INCLUDE), false, "/");  

        ServerParameter params = ServerParameter.getInstance();
        DBMananger.loadEnv();
        if(DBMananger.connDB()) {       // 数据库连接成功,再载入APP配置
            params.addAttribute("connDBSataus", true);
            /*
             * spring mvc 外的配置 AppConfig类
             */
            AnnotationConfigWebApplicationContext rootContext = new AnnotationConfigWebApplicationContext();
            rootContext.register(AppConfig.class);
            servletContext.addListener(new ContextLoaderListener(rootContext));

        }

        /*
         * spring-mvc 上下文
         */
        AnnotationConfigWebApplicationContext springMvcContext = new AnnotationConfigWebApplicationContext();
//        springMvcContext.register(MvcConfig.class);

        /*
         * DispatcherServlet
         */
        DispatcherServlet dispatcherServlet = new DispatcherServlet(springMvcContext);
        ServletRegistration.Dynamic dynamic = servletContext.addServlet("dispatcherServlet", dispatcherServlet);
        dynamic.setLoadOnStartup(1);
        dynamic.addMapping("/");

        /*
         * CharacterEncodingFilter: 解决中文乱码问题 
         */
        CharacterEncodingFilter characterEncodingFilter = new CharacterEncodingFilter();
        characterEncodingFilter.setEncoding("utf-8");
        FilterRegistration characterEncodingfilterRegistration =
                servletContext.addFilter("characterEncodingFilter", characterEncodingFilter);
        characterEncodingfilterRegistration.addMappingForUrlPatterns(EnumSet.of(DispatcherType.REQUEST), false, "/*");
    }

}

MvcConfig 配置如下:

public class MvcConfig extends WebMvcConfigurationSupport {

    private static final Logger logger = LogManager.getLogger(MvcConfig.class);

    /**
     * 注册视图处理器
     * @return
     */
    @Bean
    public ViewResolver viewResolver() {
        logger.info("注册视图处理器-------->ViewResolver");
        InternalResourceViewResolver viewResolver = new InternalResourceViewResolver();
        viewResolver.setPrefix("/jsp/");
        viewResolver.setSuffix(".jsp");
        return viewResolver;
    }

    /**
     * 资源访问处理器
     * 可以在jsp中使用/images/**的方式访问/images/下的内容
     */
    @Override  
    public void addResourceHandlers(ResourceHandlerRegistry registry) {  
        logger.info("资源访问处理器-------->addResourceHandlers");
        registry.addResourceHandler("/resources/**")
                .addResourceLocations("/resources/")
                .resourceChain(true).addResolver(
                        new VersionResourceResolver().addContentVersionStrategy("/**"));
    }
}

结果出现No mapping found for HTTP request with URI警告,访问静态资源时为404错误。

经调试发现,在MvcConfig类中加入下面Bean,问题解决

    @Bean  
    public HandlerMapping resourceHandlerMapping() {  
        logger.info("HandlerMapping");  
        return super.resourceHandlerMapping();  
    }

为什么要显式声明该Bean,尚未得知。

另外,如果在MvcConfig类中加注解,@Configuration,在WebInitializer类中配置

        AnnotationConfigWebApplicationContext springMvcContext = new AnnotationConfigWebApplicationContext();
        springMvcContext.register(MvcConfig.class);

将会导致MvcConfig加载两次,可以注释掉其中一边。

No mapping found for HTTP request with URI [/spmvctst/sigup.do] in DispatcherServlet with name 'springMVC'表示在DispatcherServlet中找不到对应的URI映射。这个错误常见于Spring MVC框架中。根据引用和引用的警告信息,这个错误可能是因为没有在DispatcherServlet的配置文件中正确配置URI映射的处理器(Handler)。具体来说,可能是没有配置文件中添加对应的@Controller或@RequestMapping注解的类,或者没有配置文件中配置<mvc:annotation-driven/>和<context:component-scan/>标签。引用中提到了这两个标签的作用,其中<context:component-scan/>用于扫描@Controller注解的类,而<mvc:annotation-driven/>用于启动Spring MVC的注解功能。 为解决这个问题,你可以按照以下步骤进行操作: 1. 确认你的DispatcherServlet配置文件中是否正确配置了@Controller注解的类。确保这些类被正确扫描到。可以使用<context:component-scan/>标签指定要扫描的包。 2. 确认你的DispatcherServlet配置文件中是否配置了<mvc:annotation-driven/>标签。这个标签用于启动Spring MVC的注解功能,确保HandlerMapping、HandlerAdapter和ExceptionResolver等处理器被正确注册。 3. 如果上述步骤都正确配置了,但仍然出现错误,请检查你的URI是否与配置文件中的URI映射匹配。确认是否存在拼写错误或者路径错误。 通过以上步骤,可以解决"No mapping found for HTTP request"的错误,确保DispatcherServlet能够找到正确的URI映射并处理请求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [No mapping found for HTTP request with URI [/.../...] in DispatcherServlet](https://blog.csdn.net/qq_45592174/article/details/112914031)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [No mapping found for HTTP request with URI [/user/login.do] in DispatcherServlet with name 'dispatch](https://blog.csdn.net/Drrier/article/details/79892351)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值