JavaEE_Filter基本使用

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)过滤器可以在目标前做点事情,目标之后还会做点事情。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李宸净

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值