SpringMvc 第二篇
有趣的符号
今天的内容相对就比较少了 主要是讲一下今天学习遇到的很好玩的事情,
下图是配置我们上篇讲到的控制器,DispatcherServlet的web.xml中的配置
DispatcherServlet这个控制器本质上呢他是一个Serlvet,所以说我们可以在web.xml中配置它, 在第二个箭头指向的
代码语言:javascript复制 <servlet-mapping>
<servlet-name>springmvcservlet-name>
<url-pattern>/url-pattern>
servlet-mapping>
/中的这个/ 就是我说的十分有趣的点,这个代表的DispatcherServlet匹配范围, /*:代表匹配所选定的目录下所有的请求包括静态资源如 html,css,jsp等 /:代表匹配所有选定目录下的所有请求不包括静态资源
Q:这个时候就会有人提出极限二连问:他们是如何执行的呢?,我们该如何判断什么情况去使用他们呢?
关于" / * "的A:
当把所有的请求交给DispatcherServlet来处理的时候, 没有被 @RequestMapping() 映射的资源就无法成功响应,比如静态资源,jsp,html等文件 我们是不会去写@RequestMapping("/.jsp")或是@RequestMapping("/.html")这样的映射 所以当我们在/使用的是 / 的话就会导致我们的所有静态资源无法被访问 报出404等路径问题的异常状态码 所以一般我们在使用过滤器等需要覆盖全部请求的组件中使用 / 来匹配全部 流程图:
关于" / "的A:
经过阅读一些博客和讨论得知,在使用 / 来处理请求的时候 Servlet执行是有排序的,如下:
- 最先匹配jsp,优先处理(由tomcat处理)
- @RequestMapping映射的请求(由DispatcherServlet处理)
- 其他请求如html(由DispatcherServlet处理,如果没有映射则无法处理) 所以一般我们会在DispatcherServlet的配置用用到 “/” 来处理所有被@RequestMapping映射的请求 流程图:
细心的伙伴们会发现,唉这两个家伙一个匹配全部但是不包括html等的一个只匹配映射的那我们在开发中如何去两者都使用呢?
万一我既有静态也有映射的请求呢?
别着急!Spring他都想到了! 在SpringMVC.xml中mvc支持有这么两个好用的功能
mvc:default-servlet-handler/
这个功能有什么作用呢? 他将DispatcherServlet处理的请求转发给tomcat的DefaultServlet来处理,解决了静态请求的问题
mvc:annotation-driven/
这个想必大家也猜到了, 这个功能用来处理使用@@RequestMapping映射的请求
将以上二者搭配使用就可以达到让程序有效处理全部请求了 详细执行图:
今天的记录博客就到这里啦,晚安各位还在努力奋斗的小伙伴们