JavaWeb--快速入门Filter过滤器

简介: JavaWeb--快速入门Filter过滤器

一、Filter 过滤



1. Filter什么是过滤器



1、Filter过滤器它是JavaWeb的三大组件之一


三大组件分别是: Servlet 程序、Listener监听器、Filter过滤器


2、Filter过滤器它是JavaEE 的规范。也就是接口


3、Filter过滤器它的作用是:拦截请求,过滤响应


拦截请求常见的应用场景有:


1、权限检查

2、日记操作

3、事务管理

……等等


2. Filter的初体验



用户登录之后都会把用户登录的信息保存到Session域中。所以要检查用户是否登录,可以判断Session中是否包含有用户登录的信息即可!!!


<%--
  Created by IntelliJ IDEA.
  User: Jack
  Date: 2022/1/3
  Time: 9:08
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
<%
    Object user = session.getAttribute("user");
    if (user == null){
        request.getRequestDispatcher("/login.jsp").forward(request,response);
        return;
    }
%>
</body>
</html>
1


image.png

完整的体验


2.1 编写AdminFilter实现接口


package com.caq.filter;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import java.io.IOException;
public class AdminFilter implements Filter {
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
    }
    /**
     * 拦截请求,然后做权限检查
     * @param servletRequest
     * @param servletResponse
     * @param filterChain
     * @throws IOException
     * @throws ServletException
     */
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletRequest httpServletRequest = (HttpServletRequest) servletRequest;
        HttpSession session = httpServletRequest.getSession();
        Object user = session.getAttribute("user");
        //如果等于null,说明没有登录
        if (user == null) {
            servletRequest.getRequestDispatcher("/login.jsp").forward(servletRequest, servletResponse);
            return;
        } else {
            //让程序继续往下访问用户的目标资源
            filterChain.doFilter(servletRequest,servletResponse);
        }
    }
    @Override
    public void destroy() {
    }
}


2.2在xml中配置访问路径


<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">
    <!-- fileter标签用于配置一个Filter过滤器 -->
    <filter>
        <filter-name>AdminFilter</filter-name>
        <filter-class>com.caq.filter.AdminFilter</filter-class>
    </filter>
<!--    filter过滤器的拦截路径-->
    <filter-mapping>
        <filter-name>AdminFilter</filter-name>
<!--        url-pattern配置拦截路径-->
<!--            /表示请求地址为:http://ip:port/工程路径/   映射到IDEA的web目录-->
<!--            /admin/* 表示请求地址为http://ip:port/工程路径/admin/*-->
        <url-pattern>/admin/*</url-pattern>
    </filter-mapping>
    <servlet>
        <servlet-name>RegistServlet</servlet-name>
        <servlet-class>com.caq.servlet.RegistServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>RegistServlet</servlet-name>
        <url-pattern>/registServlet</url-pattern>
    </servlet-mapping>
    <servlet>
        <servlet-name>KaptchaServlet</servlet-name>
        <servlet-class>com.google.code.kaptcha.servlet.KaptchaServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>KaptchaServlet</servlet-name>
        <url-pattern>/kaptcha.jpg</url-pattern>
    </servlet-mapping>
</web-app>


2.3 打断点debug部署服务进行测试


可以看到首先经过的是filter过滤器


image.png


进行放行才会出现a.jsp的页面


image.png


3. Filter的生命周期



Filter的生命周期包含几个方法


1、构造器方法


2、init初始化方法


第1,2步,在 web工程启动的时候执行( Filter已经创建)


3、doFilter过滤方法


第3步,每次拦截到请求,就会执行


4、destroy销毁


第4步,停止 web工程的时候,就会执行(停止web工程,也会销毁Filter过滤器)


4. FilterConfig类

FilterConfig 类见名知义,它是Filter过滤器的配置文件类。


Tomcat每次创建Filter 的时候,也会同时创建一个FilterConfig类,这里包含了Filter配置文件的配置信息。


FilterConfig 类的作用是获取filter 过滤器的配置内容


1、获取Filter的名称filter-name 的内容


2、获取在 Filter 中配置的init-param初始化参数


3、获取ServletContext对象


5. FilterChain 过滤器链


FilterChain 就是过滤器链(多个过滤器如何一起工作)


image.png


6. Filter的拦截路径


精确匹配


<url-pattern>/target.jsp</url-pattern>


表示请求地址必须为:http://ip:port/工程路径/target.jsp


目录匹配


<url-pattern>/admin/*</url-pattern>


表示请求地址必须为:http://ip:port/工程路径/admin/*


后缀名匹配


<url-pattern>*.html</url-pattern>
表示请求地址必须是.html结尾才会拦截到
<url-pattern>*.do</url-pattern>
表示请求地址必须以.do结尾才会拦截到
<url-pattern>*.action</url-pattern>
表示请求地址必须以.action结尾才会拦截到


Filter过滤器只关心请求地址是否匹配不关心资源是否存在


相关文章
|
22天前
|
监控 Java 数据管理
java会话跟踪和拦截器过滤器
本文介绍了Web开发中的会话跟踪技术——Cookie与Session,以及过滤器(Filter)和监听器(Listener)的概念和应用。Cookie通过在客户端记录信息来识别用户,而Session则在服务器端保存用户状态。过滤器用于拦截和处理请求及响应,监听器则监控域对象的状态变化。文章详细解释了这些技术的实现方式、应用场景和主要方法,帮助开发者更好地理解和使用这些工具。
38 1
|
3月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
439 37
|
2月前
|
前端开发 Java 应用服务中间件
Javaweb学习
【10月更文挑战第1天】Javaweb学习
33 2
|
2月前
|
安全 Java Android开发
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
60 5
|
3月前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
|
3月前
|
安全 Java Android开发
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
116 2
|
3月前
|
SQL JSON JavaScript
JavaWeb基础9——VUE,Element&整合Javaweb的商品管理系统
Vue 指令、生命周期、this和$、vue脚手架进行模块化开发/ElementUI框架、综合案例,element商品列表展示增删改查
JavaWeb基础9——VUE,Element&整合Javaweb的商品管理系统
|
4月前
|
SQL Java 关系型数据库
【前端学java】JDBC快速入门
【8月更文挑战第12天】JDBC快速入门
34 2
【前端学java】JDBC快速入门
|
3月前
|
监控 前端开发 Java
Java里的过滤器和拦截器是什么原理,如何选择?
Java里的过滤器和拦截器是什么原理,如何选择?
31 0
|
4月前
|
安全 Java API
Java 8 流库的魔法革命:Filter、Map、FlatMap 和 Optional 如何颠覆编程世界!
【8月更文挑战第29天】Java 8 的 Stream API 通过 Filter、Map、FlatMap 和 Optional 等操作,提供了高效、简洁的数据集合处理方式。Filter 用于筛选符合条件的元素;Map 对元素进行转换;FlatMap 将多个流扁平化合并;Optional 安全处理空值。这些操作结合使用,能够显著提升代码的可读性和简洁性,使数据处理更为高效和便捷。
138 0