什么是过滤器
当浏览器向服务器发送请求的时候,过滤器可以将请求拦截下来,完成一些特殊的功能,比如:编码设置、权限校验、日志记录等。
过滤器执行流程
package com.by.servlet;
import javax.servlet.*;
import java.io.IOException;
public class FilterServletDemo implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
//真正执行过滤业务的方法
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
//设置请求编码格式
servletRequest.setCharacterEncoding("UTF-8");
//设置响应编码格式
servletResponse.setContentType("text/html;charset=utf-8");
//获取前端传送过来的数据
System.out.println("请求进来,经过过滤器......");
//一个web路径,可以配置多个过滤器,这多个过滤器就被称为过滤器链
filterChain.doFilter(servletRequest,servletResponse);
System.out.println("响应过去,经过过滤器.....");
}
@Override
public void destroy() {
}
}
使用过滤器需要注意的事项:
1.过滤器必须实现Filter接口。
2.过滤器拦截的请求执行完毕之后,必须要放行,否则我们的请求就不会被执行。
filterChain.doFilter(request,response); //过滤器放行
3.在web.xml来配置过滤器要拦截的资源,当然我们也可以通过xml的方式配置过滤器。
filterServlet
com.by.servlet.FilterServletDemo
filterServlet
/*
Filter的拦截路径的配置
1.拦截具体的资源路径:/index.jsp,只有访问index.jsp的时候才会被拦截
2.目录拦截:/user/*,访问/user下的所有资源,都会被拦截
3.后缀名拦截:*.jsp 访问后缀名为jsp的资源,都会被拦截
4.拦截所有:/* 访问所有的资源,都会被拦截
1.创建servlet
package com.by.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 FilterTestServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req,resp);
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//通过前端的input的name属性获得前端发送的数据
String username = req.getParameter("username");
String password = req.getParameter("password");
System.out.println("username:"+username+" ==password:"+password);
//通过浏览器将获得的数据返回到前端界面上,Servlet响应数据到客户端的时候,如果是中文的话,会乱码
resp.getWriter().write("username:"+username+" ==password:"+password);
}
}
2.在web.xml中配置servlet
filterTest
com.by.servlet.FilterTestServlet
filterTest
/filterTest
3.创建filter_test.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
Title
是什么?
监听器可以监听就是在servletContext,session,request三个对象创建、销毁或者往其中添加修改删除属性时自动执行代码的功能组件。
Listener分类:Javaweb提供了8个监听器(接口)
package com.by.servlet;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
public class ListenServletDemo implements ServletContextListener {
//监听Servlet上下文对象创建的方法
@Override
public void contextInitialized(ServletContextEvent servletContextEvent) {
System.out.println("==============tomcat启动,调用contextInitialized=======================");
}
//监听Servlet上下文对象销毁的方法
@Override
public void contextDestroyed(ServletContextEvent servletContextEvent) {
System.out.println("==============tomcat关闭,调用contextDestroyed=======================");
}
}
com.by.listen.MyListener
过滤器
1、是什么?
Filter(过滤器)是一个特殊的servlet,能过滤所有的请求
2、作用?
设置编码格式
3、怎么使用
public class FilterServletDemo implements Filter {
... ...
}
十四、监听器
1、是什么?
监听器可以监听ServletContext、session、request对象的创建和销毁,以及其属性的添加、修改、删除时自动执行的代码
2、怎么使用
public class ListenServletDemo implements ServletContextListener {
... ...
}