SpringMVC,3种不同的URL路由配置方法

1. 先说说一种比较常见的:

    <servlet>
        <servlet-name>theDispatcher</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:spring/spring-mvc-servlet.xml</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>theDispatcher</servlet-name>
        <url-pattern>*.html</url-pattern>
    </servlet-mapping>

让SpringMVC只拦截动态请求,js、css、img等静态资源不经过Spring,直接让Web容器处理。如果配置了拦截器,也只会拦截.html动态请求。

静态资源不走Spring,也不走拦截器,性能当然是比较好的。如果使用了Nginx,配置静态资源拦截,让Nginx处理静态资源的访问。

因为Nginx在处理静态资源方面,比Tomcat等Web容器要强。

缺点:这种拦截动态请求的方法,比较死板。

2.  我自己经常有一种需求,http://FansUnion.cn/news 这种不指定.html后缀的其实也是动态请求,所以我在配置url-pattern喜欢用“/”,即拦截所有的请求。

URL是可以灵活配置了,问题又来了,静态资源不再由Tomcat处理,所以必须在SpringMVC中再次配置

<mvc:resources mapping="/static/**" location="/static/" />

让SpringMVC把static静态资源也处理了。显然,让SpringMVC处理静态资源的性能没有Tomcat直接处理比较高。

理论上,请求中转的次数越多, 性能越差。

本以为万事大吉,虽然静态资源的性能较低,至少程序可以正常运行了,“反正是混过去了”。

进一步的需求,如果在Spring中配置了登录等拦截器,这个时候也会把 静态资源给拦截进来。

<mvc:resources mapping="/static/**" location="/static/" />

这种URL映射,也无法逃脱拦截器的魔爪。

我是怎么发现这个问题的呢?

public class BaseLoginInterceptor extends HandlerInterceptorAdapter { 

    public boolean preHandle(HttpServletRequest request,
            HttpServletResponse response, Object handler) throws Exception {

        LoginUtil.setCurrentUser(null);
        initCurrentUser(request, response);
        HandlerMethod handlerMethod = (HandlerMethod) handler;
    }
}

公司的项目,Boss的登录拦截器配置如上,“HandlerMethod handlerMethod = (HandlerMethod) handler;”。但是我在自己的项目中,发现这行代码是有问题的。

如果静态资源被拦截到,会报错:

java.lang.ClassCastException: org.springframework.web.servlet.resource.ResourceHttpRequestHandler cannot be cast to org.springframework.web.method.HandlerMethod

通过异常可以发现,Object handler是 ResourceHttpRequestHandler,而不是HandlerMethod。

因为mvc:resources把静态资源请求交给了 ResourceHttpRequestHandler 处理,因此强制转换是有问题的。

公司项目中Boss的配置之所以没有出现问题,是因为他配置的是只拦截“.html” 动态请求,所以强制转换总是成立的。

---------------------------------------------

我们分析了上述两种情况, 发现“根本矛盾”“根本需求”是啥?

1.动态请求的URL应该非常灵活,/news /news.html都应该算作动态请求。

2.SpringMVC的url-pattern可以配置 / , *.html,或者正则表达式,但是我不太喜欢用正则表达式。

3.如果可能,SpringMVC最好不要拦截静态资源,让Tomcat容器直接处理更好。

<mvc:resources mapping="/static/**" location="/static/" />

这是为了性能考虑。

4.如果线上服务器配置了Nginx,我可以选择让Nginx拦截静态请求,因为比Tomcat处理性能更高。

本地是否配置Nginx,都不需要改动任何代码。

-------------------------------------------------

上面说的 第一种方法的缺陷是,url配置不够灵活。

第二种方法的缺陷是,SpringMVC要拦截静态资源,而且登录拦截器 也会拦截 静态资源,不但性能差,程序还得再次修改,判断HandlerMethod的实际类型。

3.终极解决方案:

以我习惯用的第2种方法为基础,进一步改进:

去掉 <mvc:resources mapping="/static/**" location="/static/" />,不做静态资源请求的映射。

在web.xml里增加如下配置:

    <servlet-mapping>
        <servlet-name>default</servlet-name>
        <url-pattern>/static/*</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
        <servlet-name>default</servlet-name>
        <url-pattern>*.js</url-pattern>
    </servlet-mapping>
    <servlet-mapping>
        <servlet-name>default</servlet-name>
        <url-pattern>*.css</url-pattern>
    </servlet-mapping>

激活Tomcat的defaultServlet来处理静态文件。

这样 SpringMVC不再响应静态资源,登录拦截器也没有问题了。

时间: 2024-11-05 19:03:25

SpringMVC,3种不同的URL路由配置方法的相关文章

SpringMVC,3种不同的URL路由配置方法 [转]

SpringMVC中配置URL拦截,非常简单.网上找个示例,就能通过.但是,在我做了好几个Web项目,又参与了别人主导的Web项目时,发现URL配置也非常有学问. 1. 先说说一种比较常见的: <servlet> <servlet-name>theDispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-clas

SpringMVC,3种不同的URL路由配置方法(这根本不是一个小问题)

SpringMVC中配置URL拦截,非常简单.网上找个示例,就能通过.但是,在我做了好几个Web项目,又参与了别人主导的Web项目时,发现URL配置也非常有学问. 1. 先说说一种比较常见的: <servlet> <servlet-name>theDispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-clas

8.MVC框架开发(URL路由配置和URL路由传参空值处理)

1.ASP.NET和MVC的路由请求处理 1)ASP.NET的处理 请求---------响应请求(HttpModule)--------处理请求(HttpHandler)--------把请求的资源处理之后返回给客户端 2)MVC的处理 由ASP.NET衍生出来,也遵循请求.响应.处理.资源返回给客户端的过程 请求-----URLRoutingModule(响应路由请求)-----RoutingTable(路由表)(检索请求路径是否和路由表里的路由匹配)-----生成一个路由映射,生成一个Ro

django中url路由配置及渲染方式

今天我们学习如何配置url.如何传参.如何命名.以及渲染的方式,内容大致有以下几个方面. 创建视图函数并访问 创建app django中url规则 捕获参数 路径转换器 正则表达式 额外参数 渲染方式 创建视图并访问 项目中自带的Python文件中,并没有带有视图,因此我们自己创建一个,通常,我们把视图命名views.py. 然后在views.py中,导入头文件  from django.http import HttpResponse 然后我们在views.py中,写一些Python函数,用来

url路由配置及渲染方式

-- django的url规则 django的路由系统 当一个请求来到时 1.首先到项目目录下的urls.py (根URLconf模块)中,查找路由规则 2.根URLconf模块,里面定义了urlpatterns变量 3.urlpatterns是一个(django.urls.path,django.urls.re_path 对象)列表 4.按顺序运行每个url模式.在第一个匹配的模板停止 5.一旦匹配,django 导入并调用给定的视图 6.如果中间出错,或者没有匹配到,返回404 -- pat

linux 双线路由配置方法

注意:此方法联通网卡不可加联通网关,否则会和电信网关冲突,无法上网. 此路由表为2013年10月份资料,如有更新请自行更改或留言 一.添加手动路由表.(此方法可实现服务器通过双线路由,电信走电信,联通走联通.但是会出现外部电信访问联通IP时无法正常访问的情况) 1.编辑/etc/rc.loacl 在最下面插入如下代码 chmod 775 /etc/sysconfig/network-scripts/routelist.sh /etc/sysconfig/network-scripts/route

[.net core]7 4种app key value的配置方法及优先顺序

就是这货 点开查看内容 { "Logging": { "LogLevel": { "Default": "Warning" } }, "AllowedHosts": "*" } 可以在里面加上自己的key value配置 ,比如 { "Logging": { "LogLevel": { "Default": "Warn

ThinkPHP URL 路由功能详解与实例

本节内容导读 本节内容主要介绍 ThinkPHP 路由功能与 U方法的使用,分为下面几个部分: ThinkPHP URL 路由功能详解:见本页下面文字 ThinkPHP 正则路由与实例 ThinkPHP U方法:使用U方法自动生成URL超链接 ThinkPHP 3.0 版本的路由功能较 2.x 版本有较大的变更,如果您的版本是 2.x,请参阅下面的文档: ThinkPHP 2.0 URL 路由(2.0版本适用) ThinkPHP 泛路由使用详解(2.0版本适用) ThinkPHP 2.1 路由规

Django之url路由

Django之url路由 url路由介绍 url路由是关联url及其视图函数关系的过程. 作用就是使views里面处理数据的函数与请求的url建立映射关系 url路由配置 Django的url路由配置在settings.py文件中ROOT_URLCONF变量指定全局路由文件名称. 注意:默认创建项目的时候,就会配置好,如果想使用别的配置文件自行修改. Django的URL路由流程 Django查找全局urlpatterns变量(urls.py) 按照先后顺序,对URL逐一匹配urlpattern