过滤器的四种拦截方式

<dispatcher>REQUEST</dispatcher>默认的!(请求)

  <dispatcher>FORWARD</dispatcher>

  <dispatcher>INCLUDE</dispatcher>

  <dispatcher>ERROR</dispatcher>

在<filter-mapping>中进行配置:

request请求中,会牵扯到转发和重定向,可以是页面,也可以是servlet请求路径,如果想要拦截转发这种的请求时,需要在对应的拦截器上边添加一个参数(<dispatcher>FORWARD</dispatcher>),类似于:(FORWARD和INCLUDE使用一样,只是名字不同)

<filter-mapping>
    <filter-name>InterceptorFilter</filter-name>
    <url-pattern>/*</url-pattern>
    <dispatcher>FORWARD</dispatcher>
  </filter-mapping>

这样的话,转发过来的操作就会进入对应的拦截器里边,不然不会进入,需要注意;对应ERROR这样的拦截器也是一样,也需要这样配置,和转发一样,都是因为这是jsp内部直接触发的跳转,不是外界直接通过浏览器去访问的触发的,所以跟平常的那种request请求拦截方式不太一样,需要额外配置参数,需要注意

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
.NET 5 引入了新的过滤器拦截器的概念来帮助我们在应用程序中实现更好的控制和可重用性。虽然它们的目的相似,但它们在实现上有一些差异。 过滤器是一种在应用程序中处理请求和响应的方式。它们可以在整个应用程序生命周期中应用,并且可以应用于控制器、动作和全局级别。过滤器可以用于处理身份验证、授权、异常处理等操作。过滤器可以通过实现特定的接口(例如 IActionFilter,IAuthorizationFilter 等)或继承抽象类(例如 ActionFilterAttribute,AuthorizeAttribute 等)来创建自定义过滤器。它们提供了在请求和响应的不同阶段中执行代码的机制。 拦截器是在方法调用前后进行拦截和处理的一种机制。它们主要用于 AOP(面向切面编程)的实现,并且可以应用于控制器、动作、服务和全局级别。与过滤器不同,拦截器只能用于方法调用。拦截器可以通过实现 IInterceptor 接口或继承抽象类(例如 InterceptorAttribute)来创建自定义拦截器。它们提供了在方法执行前后进行代码注入和处理的能力,并可以修改方法的输入参数和输出结果。 尽管过滤器拦截器的目的相似,但它们在应用方式和适用范围上有所不同。过滤器更注重于请求和响应的处理,并且可以在全局范围内应用,而拦截器更注重于方法的拦截和处理,并且仅适用于方法调用。具体使用哪种方式取决于应用程序的需求和设计。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值