从零开始:全面解析JavaWeb中的Filter与Listener(下)

过滤器(Filter)

1.什么是过滤器

过滤器实际上就是对web资源进行拦截,做一些处理后再交给下一个过滤器或servlet处理,通常都是用来拦截request进行处理的,也可以对返回的response进行拦截处理。

2.过滤器的语法格式

2.1.创建一个类实现Filter接口

public class CharSetFilter implements Filter{}

2.2.重写接口中的方法

import javax.servlet.*;
import java.io.IOException;

public class MyFilter implements Filter {

    // 初始化方法
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        // 执行一些初始化操作,比如读取配置参数
        System.out.println("过滤器初始化");
    }

    // 过滤方法
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        // 在请求处理前执行的操作
        System.out.println("请求处理前的操作");

        // 将请求传递给下一个过滤器或目标资源
        chain.doFilter(request, response);

        // 在响应处理后执行的操作
        System.out.println("响应处理后的操作");
    }

    // 销毁方法
    @Override
    public void destroy() {
        // 进行一些资源释放操作
        System.out.println("过滤器销毁");
    }
}

2.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>

3.使用场景

3.1.如何防止用户未登录就执行后续操作

String name=(String)session.getAttribute("key"); if(name==null){

//跳转到登录页面

}

过滤器的特点:servlet之前和之后都会被执行

监听器(Listener)

1.什么是监听器

监听器就是监听某个域对象的的状态变化的组件 监听器的相关概念: 事件源:被监听的对象(三个域对 requestsessionservletContext) 监听器:监听事件源对象事件源对象的状态的变化都会触发监 听器 注册监听器:将监听器与事件源进行绑定 响应行为:监听器监听到事件源的状态变化时所涉及的 功能代码(程序员编写代码)

2.监听器分类

第一维度按照被监听的对象划分:ServletRequest域、HttpSession域、ServletContext 第二维度按 照监听的内容分:监听域对象的创建与销毁的、监听域对象的属性变化的

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

 

监听器的编写步骤(重点):

编写一个监听器类去实现监听器接口 覆盖监听器的方法 需要在web.xml中进行配置注册

<listener>

<listener-class>监听器所在的路径</listener-class>
</listener>

ServletContextListener

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

Servlet域的生命周期

何时创建:服务器启动创建 何时销毁:服务器关闭销毁

ServletContextListener监听器的主要作用

初始化的工作:初始化对象、初始化数据(加载数据库驱动、连接池的初始化) 加载一些初始化的配置 文件(spring的配置文件) 任务调度(定时器—Timer/TimerTask

HttpSessionListener

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

HttpSession对象的生命周期

何时创建:第一次调用request.getSession时创建 何时销毁:服务器关闭销毁、session过期(默认30分钟,修改默认的30分钟是在Tomcatweb.xml,修改当前项目的过期时间是在自己项目的web.xml中)、手动销毁

HttpSessionListener监听器的主要作用:

由于每次访问网站都会默认创建session对象(jsp页面中page指令中的session属性默认为true,即被访问时创建session),可以用于计数网站访问过的人

ServletRequestListener

监听ServletRequest域创建与销毁的监听器 ServletRequest的生命周期

创建:每一次请求都会创建request

销毁:请求结束

用法同上,用处不是很大,此处省略。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值