过滤器&监听器

过滤器&监听器

监听器

​ Filter是实现特定接口的普通java程序,拦截Request请求的对象,在用户的请求访问资源前处理ServletRequest以及ServletResponse。

图0

​ 当浏览器发送请求给服务器的时候,先执行过滤器,然后才访问Web的资源。服务器响应Response,从Web资源抵达浏览器之前,也会途径过滤器。

Filter生命周期
  • void init(FilterConfig):Filter实例会在服务器启动时就创建,创建完之后调用init()方法完成初始化。
  • void doFilter(ServletRequest,ServletResponse,FilterChain):每次请求时执行,来决定释放用户是否能访问到目标资源。在doFilter中实现访问ServletRequest,ServletResponse。这也就意味着允许给ServletRequest增加属性或者增加Header。当然也可以修饰ServletRequest或者ServletResponse来改变它们的行为。
  • void destory():一般服务器在关闭时销毁Filter对象,销毁之前调用destory()方法。
FilterConfig

init方法中FilterConfig参数的作用
filterConfig.getServletContext();//获取ServletConfig对象
filterConfig.getFilterName();//获取过滤器名字
filterConfig.getInitParameterNames();//获取初始值的name,返回值是枚举类型
filterConfig.getInitParameter("");//获取参数name对应的value值

<filter>
         <filter-name>FilterDemo1</filter-name>
         <filter-class>FilterDemo1</filter-class>
         <init-param>
             <param-name>word_file</param-name>    
             <param-value>/WEB-INF/demo.txt</param-value>
         </init-param>
</filter>
<filter-mapping>
         <filter-name>FilterDemo1</filter-name>
         <url-pattern>/*</url-pattern>
</filter-mapping>

用于注册过滤器
:指定过滤器名称,filterConfig.getFilterName()返回这个值。
:指定过滤器对应的万盏的类名。
:指定过滤器初始化参数,filterConfig.getInitParameter("")方法用子元素指定的参数名字,返回指定的参数的值。
元素用于设置一个Filter 所负责拦截的资源。
:设置 filter 所拦截的请求路径

过滤器的执行顺序

​ 一个资源可能被多个Filter关联到(Filter链条),这时调用Filter.doFilter()的方法将触发Filter链条中下一个Filter。只有当Filter链条中的最后一个Filter里调用的FilterChain.doFilter(),才会触发处理资源的方法。
​ 的配置顺序决定了过滤器的执行顺序。如果是通过注解的方式配置,就比较urlPatterns的字符串优先级。

AFilter.java

public class AFilter implements Filter {
   
	public void destroy() {
   }
	public void doFilter(ServletRequest request, ServletResponse response,
			FilterChain filterChain) throws IOException, ServletException {
   
		System.out.println("AFilter#start");
		filterChain.doFilter(request, response);// 触发下一个过滤器或者触发访问资源
		System.out.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
拦截器、过滤器监听器是在软件开发中常用的三种组件,用于对请求进行干预、选择和获取事件细节。它们的区别如下[^1][^2]: 1. 拦截器(Interceptor): 拦截器用于在请求进行中干预其进展,并可以控制是否终止请求的执行。拦截器可以在请求前、请求后或请求完成后执行特定的操作,例如记录日志、权限验证等。 2. 过滤器Filter): 过滤器用于从一堆东西中选择符合特定要求的内容。它可以定义一些规则或条件,根据这些规则或条件来过滤出符合要求的内容。过滤器通常用于对请求进行预处理或后处理,例如请求参数的校验、字符编码的转换等。 3. 监听器(Listener): 监听器用于获取事件发生的细节,而不对事件的执行过程进行干预。当特定事件发生时,监听器可以捕获该事件并执行相应的操作。监听器通常用于记录日志、统计数据等。 示例代码如下: ```java // 拦截器示例 public class MyInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 在请求前执行的操作 return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { // 在请求后执行的操作 } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // 在请求完成后执行的操作 } } // 过滤器示例 public class MyFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { // 过滤器初始化操作 } @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // 过滤器处理请求的操作 chain.doFilter(request, response); } @Override public void destroy() { // 过滤器销毁操作 } } // 监听器示例 public class MyListener implements ServletContextListener { @Override public void contextInitialized(ServletContextEvent sce) { // 监听器初始化操作 } @Override public void contextDestroyed(ServletContextEvent sce) { // 监听器销毁操作 } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值