不加<mvc:resource >能扫描到controller里的mapping:
INFO 11-13 11:04:11(AbstractHandlerMethodMapping.java:543): Mapped "{[/aaa]}" onto public java.lang.String com.taotao.web.PageController.index()
INFO 11-13 11:04:11(AbstractHandlerMethodMapping.java:543): Mapped "{[/test]}" onto public java.lang.String com.taotao.web.QureyNowController.qrNow()
加上如下配置后,日志中未打印上述日志,访问页面返回404:
<mvc:resources mapping="/js/**" location="/WEB-INF/js"/>
<mvc:resources mapping="/css/**" location="/WEB-INF/css"/>
排查后发现springmvc.xml中没有加入mvc:annotation-driven配置,加上后,成功加载页面
<mvc:annotation-driven/>
以下为了解的<mvc:annotation-driven/>作用:
- <mvc:annotation-driven/>相当于注册了DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter两个bean,配置一些messageconverter。即解决了@Controller注解的使用前提配置。
- 最后的配置如果没有<mvc:annotation-driven/>,那么所有的Controller可能就没有解析,所有当有请求时候都没有匹配的处理请求类,就都去<mvc:default-servlet-handler/>即default servlet处理了。添加上<mvc:annotation-driven/>后,相应的do请求被Controller处理,而静态资源因为没有相应的Controller就会被default servlet处理。总之没有相应的Controller就会被default servlet处理就ok了。