【问题描述】
今儿组里一人问我个问题:
为什么在web工程webapp目录下建了一个jsp页面,http://localhost:8080/bppp-web/NewFile.jsp可以直接访问?
为什么同样在web工程webapp目录下建了一个html页面,http://localhost:8080/bppp-web/NewFile.html访问却报404?
我第一反应是应该都可以,其实不是
【分析】
该web工程使用spring+spring mvc+mybatis框架,在工程web.xml文件中配置了spring mvc的前置控制器DispatcherServlet,如下图所示:
DispatcherServlet会对匹配的请求进行拦截,当拦截的url-pattern设置的是 / 时,就不会匹配到*.jsp的URL,但会匹配*.html和形如/user的URL,所以,当拦截到*.html后,就会进入spring mvc的DispatcherServlet类,然后去寻找controller,接着找不到对应的controller,资源找不到、所以报404。
【解决方法】
方法一:将上面方框中的代码注释掉;
方法二:web.xml添加如下代码(激活defaultServlet来处理静态文件):
<servlet-mapping>
<servlet-name>default</servlet-name>
<url-pattern>*.html</url-pattern>
</servlet-mapping>
注意:考虑性能问题,最好将上面代码写在spring mvc的DispatcherServlet的前面,否则程序需要先执行DispatcherServlet拦截*.html请求,然后再执行defaultServlet时,又放开*.html请求,多走了一步。
方法三:修改<url-pattern>的值,改为不匹配“*.html”的表达式,如:
<url-pattern>/system/*</url-pattern>、
<url-pattern>*.do</url-pattern>、
<url-pattern>*.htm</url-pattern>
这个需根据实际项目来,可能需要和spring的配置文件中viewResolver的前缀后缀配合使用。
<url-pattern>的/和/*的区别可参见:https://blog.csdn.net/dingfei136913/article/details/78845021
【附:】名词官方解释
defaultServlet:是既服务于静态资源又服务于目录列表(如果允许目录列表的话)的servlet;通过defaultServlet我们可以通过链接访问应用内的资源文件,例如.jpg、.html、.js、.css、.jpg这类的静态文件。
DispatcherServlet:spring mvc的前置控制器,配置在web.xml文件中的。拦截匹配的请求,Servlet拦截匹配规则要自己定义,把拦截下来的请求,依据相应的规则分发到目标Controller来处理,是配置spring MVC的第一步。