servlet过滤器Filter简要回顾-过滤请求字符编码,/和/*和/**的区别

导读:本篇文章讲解 servlet过滤器Filter简要回顾-过滤请求字符编码,/和/*和/**的区别,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

servlet过滤器

1.filter过滤器的含义

它主要用于对用户请求进行预处理,也可以对HttpServletResponse进行后处理。使用Filter的完整流程:Filter对用户请求进行预处理,接着将请求交给Servlet进行处理并生成响应,最后Filter再对服务器响应进行后处理。servlet的过滤器,通过实现Filter接口来实现。

过滤器的本质:过滤一些非法请求(常见的场景就是非法登录验证,以及一些需要登录后才能去访问的页面和资源),在浏览器和服务器响应中间添加一个拦截过滤请求的容器。

比如针对非法登录的用户的请求过滤:
当我们使用了Filter过滤器的时候,同样的场景,用户每一次发送请求的时候都要经过Filter过滤器,那么我们可以在过滤器里面编辑逻辑代码,进行判断当用户没有登录的时候,我们就让他跳转到提示错误的页面,在提示错误的页面里提示他只有登录了之后才可以访问系统主页。

在这里插入图片描述

2.filter过滤器的使用

首先,需要引入对应的包 javax.servlet,和HttpServlet是同一个包下。

filter接口源码:

package javax.servlet;

import java.io.IOException;

public interface Filter {
    default void init(FilterConfig filterConfig) throws ServletException {
    }

    void doFilter(ServletRequest var1, ServletResponse var2, FilterChain var3) throws IOException, ServletException;

    default void destroy() {
    }
}

创建一个类,实现filter接口,并且重写它的三个方法即可:

package com.robin.filter;

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

public class MyFilter implements Filter {
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        Filter.super.init(filterConfig);
    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        // 编写自己的业务逻辑代码即可
    }

    @Override
    public void destroy() {
        Filter.super.destroy();
    }
}

接着,去web.xml中配置过滤器:

 	<!--  过滤器配置  -->
    <filter>
     	<!-- 过滤器名 -->
        <filter-name>MyFilter </filter-name>
         <!--过滤器对应的全类名 -->
        <filter-class>com.robin.filter.MyFilter</filter-class>
    </filter>
    <!--过滤器拦截请求映射 -->
    <filter-mapping>
    	<!-- 过滤器名与上面的一致 -->
        <filter-name>MyFilter </filter-name>
        <!--   过滤请求配置 下面的相当于过滤servlet包下的所有请求   -->
        <url-pattern>/servlet/*</url-pattern>
    </filter-mapping>

3.测试-过滤字符编码正确响应中文编码

3.1 创建servlet用于显示中文字符

package com.robin.servlet;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class ShowServlet extends HttpServlet {

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        resp.getWriter().write("我是中文字符");
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doGet(req, resp);
    }
}

3.2 自定义过滤器

package com.robin.filter;

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

/**
 * 自定义字符过滤器
 */
public class CharacterEncodingFilter implements Filter {

    // 过滤器初始化
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        System.out.println("CharacterEncodingFilter初始化");
        Filter.super.init(filterConfig);
    }

    //
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        // 设置过滤器的功能
        servletRequest.setCharacterEncoding("utf-8");
        servletResponse.setCharacterEncoding("utf-8");
        servletResponse.setContentType("text/html;charset=utf-8");

        System.out.println("CharacterEncodingFilter过滤器执行之前");
        // 将自定义过滤器加入过滤器链中 filterChain 如果不加入链中,是无法执行过滤器的功能,以及拦截请求
        filterChain.doFilter(servletRequest,servletResponse);
        System.out.println("CharacterEncodingFilter过滤器执行之后");
    }

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

3.3 配置web.xml中的servlet映射以及过滤器请求拦截

<?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">
    <!--  servlet映射配置  -->
    <servlet>
        <servlet-name>ShowServlet</servlet-name>
        <servlet-class>com.robin.servlet.ShowServlet</servlet-class>
    </servlet>
    <!-- 配置第一个映射,走过滤器的映射   -->
    <servlet-mapping>
        <servlet-name>ShowServlet</servlet-name>
        <url-pattern>/servlet/Show</url-pattern>
    </servlet-mapping>
    <!--  第二个映射,不走过滤器,则显示字符会乱码  -->
    <servlet-mapping>
        <servlet-name>ShowServlet</servlet-name>
        <url-pattern>/Show</url-pattern>
    </servlet-mapping>
    
    <!--  过滤器配置  -->
    <filter>
        <filter-name>CharacterEncodingFilter</filter-name>
        <filter-class>com.robin.filter.CharacterEncodingFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>CharacterEncodingFilter</filter-name>
        <!--   过滤servlet下的所有请求     -->
        <url-pattern>/servlet/*</url-pattern>
    </filter-mapping>
</web-app>

3.4 运行输出

先访问走过滤器的请求http://localhost:8080/servlet/Show,字符正确显示

在这里插入图片描述

访问不会走过滤器的请求http://localhost:8080/Show,则输出乱码

在这里插入图片描述

其余的非法登录验证,以及敏感字符请求过滤等,本质都一样,大家可以自行测试

4. / 和 /* 以及 /** 的区别

  1. /
    <url-pattern>/</url-pattern>
    解释:会匹配到/login这样的路径型url,.js和.html等静态资源,不会匹配到*.jsp页面

  2. /*
    <url-pattern>/*</url-pattern>
    解释:会匹配所有url(只匹配当前文件夹下文件,不匹配子文件夹下文件),包括*.jsp页面

  3. /**
    <url-pattern>/**</url-pattern>
    解释:会匹配所有url(匹配当前文件夹下文件和子文件夹下文件):路径型的和后缀型的url(包括/login,.jsp,.js和*.html等)


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由半码博客整理,本文链接:https://www.bmabk.com/index.php/post/105142.html

(0)
小半的头像小半

相关推荐

半码博客——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!