JavaWeb笔记_FilterListener

一.过滤器

1.1 过滤器概述

 过滤器主要用来拦截目标资源(静态资源或动态资源)的请求和响应

(类似地铁的安检)

我们访问动态或静态资源都要通过URL访问:http://localhost:8080/...

所以过滤器本质上拦截的是URL

1.2 过滤器使用步骤

a.新建一个类,这个类需要实现java.servlet.Filter,这个类就成为了一个拦截器

b. 在web.xml中配置这个过滤器类,还需要配置这个过滤器类拦截那些URL

/*** 将一个类实现Filter接口,那么这个类就成为一个过滤器类*/
public class FilterDemo01 implements Filter {@Overridepublic void init(FilterConfig filterConfig) throws ServletException {System.out.println("拦截器完成初始化");}@Overridepublic void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {System.out.println("filterDemo01开始执行"+servletRequest+"..."+servletResponse);filterChain.doFilter(servletRequest,servletResponse); //放行该请求System.out.println("filterDemo01结束执行"+servletRequest+"..."+servletResponse);}@Overridepublic void destroy() {System.out.println("拦截器被销毁");}
}
 <!-- 注册(配置)一个过滤器   --><filter><filter-name>filterDemo01</filter-name><filter-class>filter01.FilterDemo01</filter-class></filter><filter-mapping><filter-name>filterDemo01</filter-name><!--表示过滤器拦截哪些请求  /* 表示拦截所有请求与响应--><url-pattern>/*</url-pattern></filter-mapping>

 

1.3 单个过滤器原理

过滤器与被拦截目标资源使用的都是同一个request和response对象

      Tomcat创建request对象和response对象==>过滤器,doFilter(request,resposne)方法           中形参==>servlet中doPost(request,resposne)中形参

1.4 多个过滤器执行原理

 根据在web.xml中的匹配情况以及过滤器的注册先后顺序决定多个过滤器的拦截先后顺序

1.5 过滤器生命周期

 /**
       * Filter接口中的方法:
       *  void init(FilterConfig filterConfig):初始化过滤器方法
       *
       *  void destroy():销毁过滤器方法
       *
       *  void doFilter(ServletRequest request, ServletResponse response, FilterChain chain):拦截到指定的资源时候执行
       *
       *  1.当服务器启动的时候,就初始化web.xml中配置的过滤器
       *  2.当访问被拦截的目标资源时候,就执行doFilter()方法中的第一句
       *    执行目标资源
       *    执行chain.doFilter(request,response)下面的语句
       *  3.关闭tomcat的时候会销毁这个过滤器
       */

/*** FilterConfig可以用来获取在过滤器中配置的初始化参数*    String getInitParameter(String name):根据参数名获取参数值*/public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {System.out.println(request.getServletContext().getFilterRegistration("filterDemo02").getInitParameter("charset"));}<filter><filter-name>filterDemo02</filter-name><filter-class>filter01.FilterDemo02</filter-class><init-param><param-name>charset</param-name><param-value>UTF-8</param-value></init-param></filter><filter-mapping><filter-name>filterDemo02</filter-name><url-pattern>/*</url-pattern></filter-mapping>

1.6 过滤器拦截路径配置

  a.完全路径匹配
       /aa:只有/aa路径的时候才被拦截
       /aa/bb:只有访问/aa/bb路径时候,才会被拦截
     b.模糊路径匹配
       /*: * 匹配所有,/aa,/bb,/aa/bb,/aa/index.jsp,/aa/1.html... 都会被拦截
       /aa/*: 访问/aa/bb,/aa/cc,/aa/bb/cc...都会被拦截
     c.扩展名匹配
       *.jsp:访问index.jsp,register.jsp,....才会被拦截
       *.html:访问1.html,2.html,....才会被拦截

1.7 过滤器的注解式开发

/**
 * @WebFilter属性:
 *   initParams:配置过滤器一些初始化参数 对应web.xml中 <init-param>
 *   filterName:配置过滤器名称 对应web.xml <filter-name>
 *   servletNames:配置拦截指定名称的Servlet 根据<servlet-name>去拦截指定的servlet
 *   *urlPatterns(value):配置过滤器拦截哪些路径
 */ 

1.8 过滤器解决全局乱码案例

@WebFilter(filterName = "FilterDemo03", urlPatterns = "/*", initParams =
@WebInitParam(name = "charset", value = "UTF-8"))
public class FilterDemo03 implements Filter {public void init(FilterConfig config) throws ServletException {}public void destroy() {}@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {String charset = request.getServletContext().getFilterRegistration("FilterDemo03").getInitParameter("charset");//设置request和response的字符集request.setCharacterEncoding(charset);response.setContentType("text/html;charset="+charset);chain.doFilter(request, response);}
}

1.9 自动登录案例(基于http://t.csdnimg.cn/47Ao1进行进一步优化)

loginServlet.java

@WebServlet("/loginServlet")
public class loginServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {doPost(request, response);}@Overrideprotected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {//获取表单传过来的参数,并将参数封装为对象String username = request.getParameter("username");String password = request.getParameter("password");//将用户输入的用户名和密码封装成User对象User user = new User(username, password);//最终在数据库中查询到的 User对象User finalyUser = UserServlet.getFinalyUser(user);//判断finalyUser,若为空,则在数据库中查询不到,登录失败,反之登录成功if (finalyUser!=null) {request.setAttribute("statusCode", 100);request.setAttribute("msg", "登录成功");//将正确的user用户信息存储在session域中,当重启浏览器后,session的值将会清空request.getSession().setAttribute("user", finalyUser);//登录成功,将用户信息存储在cookie域中,以便实现自动登录, 设置生命周期后,cookie重启浏览器之后还能继续存在String autoLogin = request.getParameter("autoLogin");System.out.println(autoLogin);if (autoLogin != null && autoLogin.equals("remember-me")) {Cookie cookie = new Cookie("successUser", finalyUser.getUsername() + "#" + finalyUser.getPassword());cookie.setMaxAge(7 * 24 * 60 * 60);response.addCookie(cookie);}}else {request.setAttribute("statusCode",101);request.setAttribute("msg","用户名或密码错误");//将来在页面回显用户输入的错误信息,方便用户进行修改request.setAttribute("user",user);}//转发到login页面,与login页面公用相同的request,response对象,方便回显信息request.getRequestDispatcher("/login.jsp").forward(request,response);}
}

autoLoginFilter.java

@WebFilter(filterName = "autoLoginFilter", value = "/*")
public class autoLoginFilter implements Filter {public void init(FilterConfig config) throws ServletException {}public void destroy() {}@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {HttpServletRequest req = (HttpServletRequest) request;HttpServletResponse res = (HttpServletResponse) response;User user = (User) req.getSession().getAttribute("user");if (user != null) {chain.doFilter(req, res);} else {Cookie cookie = CookieUtils.getCookie("successUser", req.getCookies());if (cookie == null) {chain.doFilter(req, res);} else {String[] split = cookie.getValue().split("#");User finalyUser = UserServlet.getFinalyUser(new User(split[0], split[1]));if (finalyUser == null) {chain.doFilter(req, res);} else {req.getSession().setAttribute("user", finalyUser);chain.doFilter(req, res);}}}}
}

二.监听器

2.1 监听器概述

监听器主要用来监听某个对象状态变化

2.2 监听器分类

  a.监听对象的创建和销毁
      ServletRequestListener:监听Request对象的创建和销毁
      HttpSessionListener:监听Session对象创建和销毁
      ServletContextListener:监听ServletContext对象创建和销毁
    b.监听域中属性变化(属性值修改,属性创建,属性删除)
         ServletRequestAttributeListener
          HttpSessionAttributeListener
          ServletContextAttributeListener

2.3 监听器使用步骤

 a.新建一个类,需要实现监听器接口
    b.在web.xml中注册这个监听器

public class MyServletContextListener implements ServletContextListener {
    @Override
    public void contextInitialized(ServletContextEvent sce) {
        System.out.println("ServletContext被创建");
    }

    @Override
    public void contextDestroyed(ServletContextEvent sce) {
        System.out.println("ServletContext被销毁");
    }
}

 <listener>
       <listener-class>listener01.MyServletContextListener</listener-class>
   </listener>

2.4 注解方式注册监听器

 

@WebListener
public class MyServletContextListener implements ServletContextListener {
    @Override
    public void contextInitialized(ServletContextEvent sce) {
        System.out.println("ServletContext被创建");
    }

    @Override
    public void contextDestroyed(ServletContextEvent sce) {
        System.out.println("ServletContext被销毁");
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/50794.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

dps或者ppt文件判断是否加密

doc文件是否加密可以通过fib来判断&#xff0c;例如 同样的方法判断ppt也可以&#xff0c;但是在判断wps保存的dps文件时&#xff0c;提示没有加密&#xff0c;文件双击打开时又需要密码&#xff0c;查看ppt格式文档有下面发现 查看文件的二进制发现了加密标识 后面再研究doc x…

OpenCV图像滤波(4)构建图像金字塔函数buildPyramid()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 在计算机视觉和图像处理中&#xff0c;构建图像金字塔&#xff08;Image Pyramid&#xff09;是一种常用的技术&#xff0c;它生成一系列分辨率逐…

CISAW信息安全保障人员认证是否值得学习?

CISAW信息安全保障人员认证的学习难度因人而异。 如果考生具备足够的学习能力以及丰富的信息安全工作经验&#xff0c;那么考试的难度可能会相对较低。 相反&#xff0c;如果考生缺少这些条件&#xff0c;学习难度可能会相对较高。 1. 从考试内容来看&#xff0c;CISAW以概念…

Neutralinojs教程项目实战初体验(踩坑指南),干翻 electron

Neutralinojs 项目实战初体验&#xff08;踩坑指南&#xff09;&#xff0c;干翻 electron Neutralinojs 官方文档 卧槽卧槽&#xff0c;&#xff01;这个年轻人居然用浏览器把电脑关机了_哔哩哔哩_bilibili正是在下 本教程搭建的是纯原生项目&#xff0c;没有和其它前端框架…

简单快捷!Yarn的安装与使用指南

Yarn 是由 Facebook (现 Meta) 开发的包管理工具。 今天&#xff0c;我将介绍如何使用 Yarn。 目录 Yarn 的官方网站 关于安装 版本确认 开始一个新项目&#xff08;创建 package.json 文件&#xff09; 安装软件包 升级包 运行脚本 执行包的命令 卸载包 总结 Yarn 的…

低代码平台在采购管理中的革新与应用

引言 随着企业数字化转型的不断推进&#xff0c;传统的企业软件开发模式面临着诸多挑战。开发周期长、成本高、需求变更频繁等问题使得企业在快速变化的市场中难以保持敏捷性。低代码平台作为一种新的开发模式&#xff0c;凭借其“低代码”甚至“零代码”的特性&#xff0c;极大…

APT 安装软件详细教程

文章目录 APT 安装软件详细教程APT 概述APT 的基本命令APT 命令详解安装软件包更新和升级软件包删除软件包搜索和查找软件包管理软件包依赖清理软件包缓存APT 配置软件源配置自定义软件源常见问题及解决方案解决软件包依赖问题处理软件源错误其他常见问题使用 APT 的最佳实践总…

词的向量化和文本向量化

词的向量化和文本向量化 向量化one-hot编码提前准备词表不提前准备词表one-hot缺点 词向量简介词向量的定义和目标word embedding和word vector的区别onehot编码与词向量关系构建 训练方式1&#xff08;基于语言模型&#xff09;训练方式2&#xff08;基于窗口&#xff09;CBOW…

选择排序思路和算法实现

选择排序 在未排序的数组中&#xff0c;用第一个数去和后面的数比较&#xff0c;找出最小的数&#xff0c;和第一个数交换。第一个数已为已排序的数。 相当于0~7 从0~7中找到最小的数放在0 从1~7中找到最小的数放在1 从2~7中找到最小的数放在2 ...以此类推 从6~7中找到最…

从简单到复杂:9款画底纹软件让设计更生动

底纹不知道怎么画&#xff1f;快来试一试这9款软件吧&#xff0c;可以让你的设计作品更加出彩&#xff0c;相信我&#xff0c;用了就是赚到&#xff0c;分别是即时设计、Adobe Illustrator、CorelDRAW、Photoshop、AutoCAD、Inkscape、GIMP、ZebraDesigner、LabelJoy。 1、即时…

软件定义AI算力:解锁AI算力的新时代

从1964年发明CPU——即IBM System 360发布的那一年算起&#xff0c;已经过去60年&#xff0c;我们已经从传统的CPU算力时代跨越到了以GPU算力为代表的加速计算时代。尤其是随着大模型的广泛应用和AIGC技术的崛起&#xff0c;行业对GPU等AI算力的需求呈现出爆炸式的增长。据华为…

微短剧出海CPS分销推广影视平台系统搭建思维逻辑介绍

随着国内短剧市场的蓬勃发展&#xff0c;其独特的魅力与影响力已跨越国界&#xff0c;成为海外观众的新宠。这一趋势不仅推动了短剧内容的全球化传播&#xff0c;也为海外市场的CPS&#xff08;按销售分润&#xff09;分销模式提供了广阔舞台。连接内容创作者、平台运营者、系统…

VMware 的网络模式详解

VMware 的网络模式详解 使用 VMware 创建虚拟机&#xff0c;配置虚拟机网络时&#xff0c;主要有三个选项&#xff0c;分别是桥接模式、NAT 模式、仅主机模式 这三个模式到底有什么含义&#xff1f; VMware 是通过虚拟网络&#xff0c;即虚拟交换机&#xff0c;来连接物理机&…

angular入门基础教程(五)父子组件的数据通信

组件之间的通信是我们业务开发中少不了的,先了解下父子组件的通信 父组件传数据给子组件 前面&#xff0c;我们学会会动态属性的绑定&#xff0c;所以在父组件中给子组件绑定属性&#xff0c;在子组件中就可以使用这个属性了。 父组件中声明然后赋值 export class AppCompon…

智能开关助力酒店管理提升

随着科技的迅猛跃进&#xff0c;智能化浪潮席卷全球&#xff0c;酒店业亦不例外地迎来了智能化转型的新纪元。智能开关&#xff0c;作为这股浪潮中的先锋&#xff0c;凭借其尖端的通信技术和智能控制逻辑&#xff0c;正深刻改变着酒店的运营模式与顾客体验。 它不仅赋予了酒店远…

IP地址证书签发之后可以绑定到指定端口访问吗?

IP地址证书概述 IP地址证书&#xff0c;也称为IP SSL证书&#xff0c;是为互联网协议(IP)地址提供安全认证的一种证书。它包含公钥、所有者信息以及由可信的证书颁发机构(CA)签发的数字签名。通过使用公钥基础设施(PKI)&#xff0c;IP地址证书确保了网络实体之间的信任和验证。…

React基础知识 精简全面 推荐

这篇博文主要对一些刚入门react框架的同学&#xff0c;以及对react基本知识进行巩固的&#xff0c;最后就是精简一下基本知识&#xff0c;以方便自己查看&#xff0c;感谢参考&#xff0c;有问题评论区交流&#xff0c;谢谢。 目录 1.JSX 2.Props 和 State 3.组件生命周期…

基于JAVA的美妆购物商城系统/美妆销售系统的设计与实现/美妆网站的设计与开发/在线美妆购物平台

摘 要 本毕业设计的内容是设计并且实现一个基于SSM框架的美妆购物商城系统。它是在Windows下&#xff0c;JSP技术&#xff0c;以MYSQL为数据库开发平台&#xff0c;Tomcat网络信息服务作为应用服务器。美妆购物商城系统的功能已基本实现&#xff0c;主要包括用户、商品信息、…

2024电赛H题参考方案(+视频演示+核心控制代码)——自动行使小车

目录 一、题目要求 二、参考资源获取 三、参考方案 1、环境搭建及工程移植 2、相关模块的移植 4、整体控制方案视频演示 5、视频演示部分核心代码 总结 一、题目要求 小编自认为&#xff1a;此次H题属于控制类题目&#xff0c;相较于往年较为简单&#xff0c;功能也算单一&…

科普文:『 码到三十五 』Java微服务中Token鉴权设计的4种方案

吐槽~~~~~~~ Java微服务中Token鉴权设计的几种方案: 1. JWT鉴权 「概述」&#xff1a;JWT是一种用于双方之间安全传输信息的简洁的、URL安全的令牌标准。它基于JSON格式&#xff0c;包含三个部分&#xff1a;头部&#xff08;Header&#xff09;、负载&#xff08;Payload&a…