过滤器(Filter)和监听器(Listener)

本文深入探讨了Web开发中的过滤器和监听器。过滤器用于拦截请求和响应,例如在用户未登录时阻止访问特定页面。监听器则关注于域对象(如Session和ServletContext)的状态变化,可用于会话跟踪、对象创建销毁监听等。通过实例代码展示了如何使用注解配置过滤器和监听器,以实现动态拦截和状态监听功能。

过滤器

什么是过滤器

过滤器实际上就是对web资源进⾏拦截,做⼀些处理后再交给下⼀个过滤器或servlet处理,通常都是⽤来拦截request进⾏处理的,也可以对返回的response进⾏拦截处理
在这里插入图片描述

过滤器语法格式

  • 1.创建一个类实现接口
public class SignInFilter implements Filter{}
  • 2.重写接口中的方法
/*初始化⽅法 接收⼀个FilterConfig类型的参数 该参数是对Filter的⼀些配置*/
 public void init(FilterConfig filterConfig) throws ServletException {
        System.out.println("过滤器初始化");
    }

/*过滤⽅法 主要是对request和response进⾏⼀些处理,然后交给下⼀个过滤器或Servlet处理*/
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println("过滤器进行处理操作");
    }

/*销毁方法*/
 public void destroy() {
        System.out.println("过滤器已销毁");
    }
  • 3.在web.xml文件中配置
    <filter>
        <filter-name>过滤器名称</filter-name>
        <filter-class>
            过滤器所在的路径
        </filter-class>
    </filter>

    <filter-mapping>
        <filter-name>过滤器名称</filter-name>
        <url-pattern>需要过滤的资源</url-pattern>
    </filter-mapping>

通过过滤器防止用户未登录进入登录后页面

此处通过注解的方式代替在web.xml文件中配置

@WebFilter("*")
public class SignInFilter implements Filter {
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        System.out.println("过滤器初始化");
    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        System.out.println("过滤器开始操作");
        HttpServletRequest request =(HttpServletRequest) servletRequest;
        HttpServletResponse response=(HttpServletResponse) servletResponse;
        request.setCharacterEncoding("utf-8");

       String requestURI =request.getRequestURI();
        HttpSession session = request.getSession();
        Object username=session.getAttribute("username");
        if (requestURI.endsWith("SignUp.jsp")&& username==null){
            response.sendRedirect("SignIn.html");
        }
        filterChain.doFilter(servletRequest,servletResponse);
        System.out.println("过滤器结束");
    }

    @Override
    public void destroy() {
        System.out.println("过滤器已销毁");
    }
}

监听器

什么是监听器

监听器就是监听某个域对象的的状态变化的组件

监听器的相关概念:

  • 事件源:被监听的对象(三个域对象 request、session、servletContext)
  • 监听器:监听事件源对象事件源对象的状态的变化都会触发监听器
  • 注册监听器:将监听器与事件源进⾏绑定
  • 响应⾏为:监听器监听到事件源的状态变化时所涉及的功能代码(程序员编写代码)

监听器分类

第一维度

按照被监听的对象划分:ServletRequest域、HttpSession域、ServletContext域

第二维度

按照监听的内容分:监听域对象的创建与销毁的、监听域对象的属性变化的

\ServletContext域HttpSession域ServletRequest域
域对象的创建与销毁ServletContextListenerHttpSessionListenerServletRequestListener
域对象内的属性的变化ServletContextAttributeListenerHttpSessionAttributeListenerServletRequestAttributeListener

监听三大域对象的创建与销毁的监听器

监听器的编写步骤

1.编写⼀个监听器类去实现监听器接⼝
2.覆盖监听器的⽅法
3.需要在web.xml中进⾏配置—注册

示例

监听session的创建和销毁
此处通过注解的方式代替在web.xml文件中配置

@WebListener("*")
public class SessionListener implements HttpSessionListener {
    @Override
    public void sessionCreated(HttpSessionEvent httpSessionEvent) {
        System.out.println("session创建");
    }

    @Override
    public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {
        System.out.println("session移除");
    }
}

附录

ServletContextListener
监听ServletContext域的创建与销毁的监听器

Servlet域的⽣命周期
何时创建:服务器启动创建
何时销毁:服务器关闭销毁

ServletContextListener监听器的主要作⽤
初始化的⼯作:初始化对象、初始化数据(加载数据库驱动、连接池的初始化)、加载⼀些初始化的配置⽂件(spring的配置⽂件)、任务调度(定时器—Timer/TimerTask)

HttpSessionListener
监听Httpsession域的创建和销毁的监听器

HttpSession对象的⽣命周期
何时创建:第⼀次调⽤request.getSession时创建
何时销毁:服务器关闭销毁、session过期(默认30分钟,修改默认的30分钟是在Tomcat的web.xml,修改当前项⽬的过期时间是在⾃⼰项⽬的web.xml中)、⼿动销毁

HttpSessionListener监听器的主要作⽤:
由于每次访问⽹站都会默认创建session对象(jsp⻚⾯中page指令中的session属性默认为true,即被访问时创建session),可以⽤于计数⽹站访问过的⼈

ServletRequestListener
监听ServletRequest域创建与销毁的监听器

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值