Filter(过滤器)
概念:
1.Tomcat提供的一个组件,类似于Servlet机制。
2.是一个特殊的Servlet。
提问:
过滤器它过滤的是什么?什么时候使用?怎么使用?
学习步骤:
1.基本使用
2.管理机制
3.继承关系
4.特殊在哪里?思考:1)有好多请求都经过,怎么拦截?2)浏览器发送请求;内部转发;重定向 是否都能拦截?3)过滤器是否可以有多个?
5.什么场景下使用
基本使用
可以参照着Servlet,自己定义一个类,继承HttpServlet,重写方法service、doPost、doGet,两个参数HttpServletRequest、HttpServletResponse。可以抛出两个异常ServletException、IOException。告知tomcat(配置web.xml文件)
1.自己定义一个类
2. 继承HttpFilter(注意:HttpFilter类是tomcat9.0版本之后才有的,如果是tomcat9.0之前的版本可以直接实现Filter接口。)
3. 重写方法:doFilter方法;init方法和destroy方法是实现接口必须重写的。
4. 三个参数:HttpServletRequest,HttpServletResponse,FilterChain
5. 异常:ServletException,IOException
6. 配置:<filter>filter-name filter-class</filter>
<filter-mapper>filter-name url-pattern</filter-mapper>
补充:执行filter是在到达真正目标之前的一个环节,filter先执行,目标(JSP、Servlet、html)后执行。
<%--该代码是index.jsp--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>$Title$</title>
</head>
<body>
<%-- 写一个登录页面--%>
<form action="login" method="post" >
账号:<input name="aname" value="" type="text">
密码:<input name="apassword" value="" type="password">
<input name="" value="登录" type="submit">
</form>
</body>
</html>
<!--该代码是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>
<servlet-name>login</servlet-name>
<servlet-class>controller.LoginController</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>login</servlet-name>
<url-pattern>/login</url-pattern>
</servlet-mapping>
<!-- filter的配置-->
<filter>
<filter-name>filter</filter-name>
<filter-class>filter.FilterOne</filter-class>
</filter>
<filter-mapping>
<filter-name>filter</filter-name>
<url-pattern>/login</url-pattern>
</filter-mapping>
</web-app>
//该代码是普通filter类
package filter;
import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.http.HttpFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
public class FilterOne extends HttpFilter {
protected void doFilter(HttpServletRequest request, HttpServletResponse response, FilterChain chain) throws IOException, ServletException {
System.out.println("我是Filter 找我干嘛");
//区别于上述的doFilter方法
chain.doFilter(request,response);//表示放行
}
}
//该代码是普通servlet类
package controller;
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 LoginController extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("我是servlet 找我干嘛");
//1接收信息
//2.找业务层做事
//3.转发给jsp
request.getRequestDispatcher("welcome.jsp").forward(request,response);
}
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doPost(req,resp);
}
}
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
这里是欢迎页面
</body>
</html>
运行效果:
(控制台:)
(浏览器)
总结Filter从浏览器到服务器的流程图如下:
- 从代码和流程图来看:似乎Filter可以替代Servlet,功能上完全可以提到。
- 从使用上貌似不行:
1)现实生活中,目标是真正做事的,过滤器负责拦截的。
2)目标是做一件事情的,过滤器好多请求都会经过。
3)过滤器可以在目标前做点事情,目标之后还会做点事情。