1、过滤器简介
过滤器实际上就是对web资源进行拦截,做一些处理后再交给下一个过滤器或servlet处理
通常都是用来拦截request进行处理的,也可以对返回的response进行拦截处理
应用场景:
- 自动登录
- 统一设置编码格式
- 访问权限控制
- 敏感字符过滤等
2、filter生命周期相关的方法
Filter接口有三个方法,并且这个三个都是与Filter的生命相关的方法
方法 | 描述 |
---|---|
init(Filterconfig) | 代表filter对象初始化方法 filter对象创建时执行 |
doFilter(ServletRequest,ServletResponse,FilterChain) | 代表filter执行过滤的核心方法,如果某资源在已经被配置到这个filter进行过滤的话,那么每次访问这个资源都会执行doFilter方法 |
destory() | 代表是filter销毁方法 当filter对象销毁时执行该方法 |
Filter对象的生命周期:
- Filter何时创建:服务器启动时就创建该filter对象
- Filter何时销毁:服务器关闭时filter销毁
特别注意:Filter导入的包一定得是javax.servlet下的包
3、Filter的配置(web.xml配置)
在web.xml文件配置,格式如下:
<filter>
<filter-name>CharacterEncodingFilter</filter-name>
<filter-class>com.sdablog.filter.CharacterEncodingFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/servlet/*</url-pattern>
</filter-mapping>
4、Filter的作用?
-
公共代码的提取
-
可以对request和response中的方法进行增强(装饰者模式/动态代理)
-
进行权限控制
5、例子
Filter文件:
package com.sdablog.filter;
import javax.servlet.*;
import java.io.IOException;
public class CharacterEncodingFilter implements Filter {
/**
* 初始化
**/
@Override
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("初始化");
}
/** filterChain:链
* 1.过滤中的所有代码,在过滤器特定请求的时候都会被执行
* 2.必须要让过滤器继续执行
* */
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) throws IOException, ServletException {
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
response.setContentType("text/html;charset=UTF-8");
System.out.println("CharacterEncodingFilter之前……");
filterChain.doFilter(request, response); //让我们的请求继续走,如果不写,程序到这里被拦截
System.out.println("CharacterEncodingFilter执行后……");
}
/**
* 销毁:web服务器关闭的时候清理
**/
@Override
public void destroy() {
System.out.println("销毁");
}
}
servlet访问文件:
package com.sdablog.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().print("你好呀世界!");
}
}
web.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">
<servlet>
<servlet-name>ShowServlet</servlet-name>
<servlet-class>com.sdablog.servlet.ShowServlet</servlet-class>
</servlet>
<!-- “ /show ” 这个访问路径不会经过过滤器 -->
<servlet-mapping>
<servlet-name>ShowServlet</servlet-name>
<url-pattern>/show</url-pattern>
</servlet-mapping>
<!-- “ /servlet/show ”这个访问路径会经过过滤器 -->
<servlet-mapping>
<servlet-name>ShowServlet</servlet-name>
<url-pattern>/servlet/show</url-pattern>
</servlet-mapping>
<filter>
<filter-name>CharacterEncodingFilter</filter-name>
<filter-class>com.sdablog.filter.CharacterEncodingFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<!-- 只要是 /servlet下的任何请求,都会经过这个过滤器 -->
<url-pattern>/servlet/*</url-pattern>
</filter-mapping>
</web-app>
————————————————
参考这位老兄的文章:https://blog.csdn.net/weixin_40521823/article/details/80218455