<mvc:annotation-driven/>
相当于注册了DefaultAnnotationHandlerMapping
和AnnotationMethodHandlerAdapter
两个bean,配置一些message converter。即解决了@Controller
注解的使用前提配置。<context:annotation-config/>
是对包进行扫描,实现注释驱动Bean定义,同时将bean自动注入容器中使用。即解决了@Controller
标识的类的bean的注入和使用。在写配置的时候,只写了<context:component-scan/>
,并没有使用<mvc:annotation-driven/>
,servlet拦截*.do
,.do
请求可以被正确捕捉和处理。
<context:component-scan base-package="com"></context:component-scan>
web.xml
<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.xml
<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.xml
<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之后就不行了呢?
回答
最后的配置如果没有<mvc:annotation-driven/>
,那么所有的Controller可能就没有解析,当有请求时候都没有匹配的处理请求类,就都去<mvc:default-servlet-handler/>
即default servlet处理了。添加上<mvc:annotation-driven/>
后,相应的do请求被Controller处理,而静态资源因为没有相应的Controller就会被default servlet处理。总之没有相应的Controller就会被default servlet处理就ok了。