本身看了官方文档,也到网上查了下,目前理解以下:web
<mvc:annotation-driven/>
至关于注册了DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter两个bean,配置一些messageconverter。即解决了@Controller注解的使用前提配置。
<context:annotation-config/>是对包进行扫描,实现注释驱动Bean定义,同时将bean自动注入容器中使用。即解决了@Controller标识的类的bean的注入和使用。
一开始我在写配置的时候,只写了<context:component-scan/>,并无使用<mvc:annotation-driven/>,servlet拦截*.do,.do请求能够被正确捕捉和处理。代码以下
mvc-servlet.xmlspring
<context:component-scan base-package="com"></context:component-scan>
web.xmlmvc
<servlet> <servlet-name>mvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>mvc</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping>
后来为了解决静态资源访问的问题,servlet改为了拦截全部请求,即/,并添加了默认的servlet,这时候*.do请求不能被控制器捕捉了,页面错误为404。直到添加了<mvc:annotation-driven/>以后,.do请求才又能被正确捕捉和处理。代码以下
mvc-servlet.xmlapp
<context:component-scan base-package="com"></context:component-scan> <mvc:annotation-driven/> <mvc:resources mapping="/styles/**" location="/WEB-INF/resource/styles/"/> <mvc:default-servlet-handler/>
web.xmlurl
<servlet> <servlet-name>mvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>mvc</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>
是什么缘由形成这种区别的呢?为何一开始没用<mvc:annotation-driven/>的时候能够,添加了默认servlet以后就不行了呢? spa
最后的配置若是没有<mvc:annotation-driven/>,那么全部的Controller可能就没有解析,全部当有请求时候都没有匹配的处理请求类,就都去<mvc:default-servlet-handler/>即default servlet处理了。添加上<mvc:annotation-driven/>后,相应的do请求被Controller处理,而静态资源由于没有相应的Controller就会被default servlet处理。总之没有相应的Controller就会被default servlet处理就ok了。.net
总结:code
要使用spring mvc中的@Controller注解,就必需要配置<mvc:annotation-driven />,不然org.springframework.web.servlet.DispatcherServlet没法找到控制器并把请求分发到控制器。component
转载原文link:http://blog.csdn.net/jbgtwang/article/details/7359592 xml