Spring MVC过滤器-委派过滤器代理(DelegatingFilterProxy) .

本文介绍了Spring框架中DelegatingFilterProxy的配置方法及作用原理。通过将过滤器作为Spring Bean进行管理,实现了灵活的配置和管理。文章还详细解释了如何通过web.xml设置参数以调整其行为。

来源:http://blog.youkuaiyun.com/geloin/article/details/7441937

 

  org.springframework.web.filter中有一个特殊的类——DelegatingFilterProxy,该类其实并不能说是一个过滤器,它的原型是FilterToBeanProxy,即将Filter作为spring的bean,由spring来管理。

        配置DelegatingFilterProxy的常用方法如下所示:

 

<filter>
		<filter-name>testFilter</filter-name>
		<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
		<init-param>
			<param-name>targetBeanName</param-name>
			<param-value>testBean</param-value>
		</init-param>
	</filter>        
        <filter-mapping>
		<filter-name>testFilter</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>

 

         含义是有一个过滤器,它指向一个bean,这个bean在spring中的名字为testBean,testBean也必需实现javax.servlet.Filter。

        其他可以通过web.xml传递的参数如下:

        (1) contextAttribute,使用委派Bean的范围,其值必须从org.springframework.context.ApplicationContext.WebApplicationContext中取得,默认值是session;

        (2) targetFilterLifecycle,是否调用Filter的init和destroy方法,默认为false。

        所以DelegationgFilterProxy的全项配置信息如下:

        <filter>
		<filter-name>testFilter</filter-name>
		<filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
		<init-param>
			<param-name>targetBeanName</param-name>
			<param-value>testBean</param-value>
		</init-param>
                <init-param>
			<param-name>contextAttribute</param-name>
			<param-value>session</param-value>
		</init-param>
                <init-param>
			<param-name>targetFilterLifecycle</param-name>
			<param-value>false</param-value>
		</init-param>
	</filter>        
        <filter-mapping>
		<filter-name>testFilter</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>

 

ERROR [http-bio-7001-exec-11012] [QbiExceptionWebHandler.java:635] [c36881c2-ae3a-4bc8-96fc-195438c374d0] [userId:fec0741443204104b1905061e6a951a2] - login request exception catch,hostName:iZ9bq05sg6fegreqp3t7wiZ,user:fec0741443204104b1905061e6a951a2,uri:http://qbi.966599.com/auth_sso/login/config.htm common-error.log-2025-10-13 10:55:22,043 ERROR [http-bio-7001-exec-11015] [EntranceFilter.java:98] [c5d74bc7-e584-4ce7-8740-8f4a2ff93402] [userId:e4186c8f9ddb41a58b847c98b938733b] - sso access filter error: common-error.log-com.alibaba.yunbi.v2.common.util.exception.AppRuntimeException: access forbidden: /api/v2/customRole/currentUserConfig. common-error.log- at com.alibaba.yunbi.v2.sso.slot.login.PageTokenNoLoginSlot.doFilterInternal(PageTokenNoLoginSlot.java:90) common-error.log- at com.alibaba.ly.sso.adapter.core.filter.slot.FilterSlotChain.doInternalFilter(FilterSlotChain.java:32) common-error.log- at com.alibaba.ly.sso.adapter.core.filter.AuthenticationFilter.doFilter(AuthenticationFilter.java:88) common-error.log- at com.alibaba.yunbi.v2.sso.NewUserAccessFilter.doFilter(NewUserAccessFilter.java:83) common-error.log- at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) common-error.log- ... common-error.log- at com.alibaba.yunbi.server.filter.TbSessionFilter.doFilter(TbSessionFilter.java:51) common-error.log- at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) common-error.log- ... common-error.log- at com.alibaba.yunbi.server.filter.RequestOriginFilter.doFilter(RequestOriginFilter.java:51) common-error.log- at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) common-error.log- ... common-error.log- at com.alibaba.yunbi.server.filter.LocaleFilter.doFilter(LocaleFilter.java:80) common-error.log- at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) common-error.log- ... common-error.log- at com.alibaba.yunbi.server.filter.ResponseWrapperFilter.doFilter(ResponseWrapperFilter.java:54) common-error.log- at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) common-error.log- ... common-error.log- at com.alibaba.yunbi.server.filter.EntranceFilter.doFilter(EntranceFilter.java:84) common-error.log- at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346) common-error.log- ... common-error.log- at com.alibaba.yunbi.server.filter.CustomCharacterEncodingFilter.doFilterInternal(CustomCharacterEncodingFilter.java:55) common-error.log- at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) common-error.log- ... common-error.log- at com.alibaba.yunbi.server.filter.PreHandleFilter.doFilter(PreHandleFilter.java:36) common-error.log- at org.springframework.web 中文翻译
最新发布
10-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值