小白的springboot之路(十三)、过滤器、监听器、拦截器
0、前言
过滤器、监听器、拦截器在实际开发中经常需要用到,下面我们来介绍一下spring boot中如何使用;
一、------ 过滤器 -----
1、作用:
过滤器是客户端与服务器资源文件之间的一道过滤网,可以帮助我们过滤一些不符合要求的请求、可以对服务器的资源请求(如图片、文件等)进行拦截以实现一些特殊功能以及给予特殊响应;
常用作session校验、判断用户权限、过滤敏感词汇、压缩响应信息、控制URL级别访问权限等
2、实现:
使用过滤器很简单,只需要实现Filter类,重写他的三个方法即可:
init:过滤器创建时执行的方法;
destroy:过滤器销毁时执行的方法 doFilter:主方法,处理逻辑;里面有三个参数,可以通过他们获得请求的相关信息;
1)创建过滤器类 LogFilter,添加@WebFilter注解
package com.anson.common.filter; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpServletResponseWrapper;
import java.io.IOException; /**
* @description: 过滤器
* @author: anson
* @Date: 2019/12/20 6:03
*/ @WebFilter(filterName = "logfilter1", urlPatterns = "/*")
public class LogFilter implements Filter
{
private static final Logger logger = LoggerFactory.getLogger(LogFilter.class); @Override
public void init(FilterConfig filterConfig) throws ServletException
{ logger.info("----------------------->过滤器被创建");
} @Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { HttpServletRequest req = (HttpServletRequest) servletRequest;
HttpServletResponseWrapper resp = new HttpServletResponseWrapper((HttpServletResponse) servletResponse); String requestURI = req.getRequestURI();
logger.info("--------------------->过滤器:请求地址"+requestURI); //记录请求
if(requestURI.contains("info")){
// servletRequest.getRequestDispatcher("/failed").forward(servletRequest, servletResponse);
resp.sendRedirect("/failed");
}else{
filterChain.doFilter(servletRequest, servletResponse);
}
} @Override
public void destroy() { logger.info("----------------------->过滤器被销毁");
}
}
2)在启动类上加入@ServletComponentScan注解
@ServletComponentScan("com.anson.common") //用于支持过滤器、监听器注解
即可
注意:我们以上采用的注解自动注册的方式,过滤器还可以采用代码注册的方式(略),自己选用一种即可;
二、----- 监听器 -----
1、作用:
监听器用于监听web应用对象的创建、销毁、增加、修改、删除等动作的发生,并做出相应的响应处理;
常用于统计在线人数、访问量、系统加载时信息初始化;
2、分类:
ServletContextListener:对应application,用于监听ServletContex属性的操作;
HttpSessionListener: 对应session,用于监听session对象,常用于统计在线情况;
ServletRequestListener:对应request,监听request对象的属性操作;
3、实现:
1}创建监听器 OnlineSessionListener
package com.anson.common.listener; import com.anson.common.exception.GlobalExceptionHandler;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
//import javax.servlet.ServletRequestListener;
import javax.servlet.annotation.WebListener;
//import javax.servlet.http.HttpSessionEvent;
//import javax.servlet.http.HttpSessionListener; /**
* @description: TODO
* @author: anson
* @Date: 2019/12/20 6:48
*/
@WebListener
public class OnlineSessionListener implements ServletContextListener //HttpSessionListener
{
private static final Logger logger = LoggerFactory.getLogger(OnlineSessionListener.class); @Override
public void contextInitialized(ServletContextEvent servletContextEvent)
{
logger.info("系统启动了");
System.out.println("系统启动了");
} @Override
public void contextDestroyed(ServletContextEvent servletContextEvent)
{
logger.info("系统停止了");
System.out.println("系统停止了");
} //=============================
// public static int online=0;
//
// @Override
// public void sessionCreated(HttpSessionEvent httpSessionEvent)
// {
//
// online ++;
// logger.info("有用户上线了,当前在线人数:" + online);
// System.out.println("有用户上线了,当前在线人数:" + online);
// }
//
// @Override
// public void sessionDestroyed(HttpSessionEvent httpSessionEvent)
// {
// online --;
// logger.info("有用户下线了,当前在线人数:" + online);
// System.out.println("有用户下线了,当前在线人数:" + online);
// }
}
2)在启动类上加入@ServletComponentScan注解
@ServletComponentScan("com.anson.common") //用于支持过滤器、监听器注解
即可
注意:我们以上采用的注解自动注册的方式,过滤器还可以采用代码注册的方式(略),自己选用一种即可;
三、 ------ 拦截器 ------
1、作用:
拦截器是动态拦截action调用的对象,使得可以在action前后增加一些操作,也可以在action执行前停止操作;
常用于登录认证、记录操作日志、通用处理等;
2、实现:
使用过滤器很简单,只需要实现HandlerInterceptor类,重写他的三个方法即可:
preHandle:处理请求之前被调用;
postHandle:请求执行完后调用;
afterCompletion:在dispatcharservlet完全处理请求后调用,常用于记录耗时时间,也可用于进行一些资源处理操作; 1)编写拦截器类MyInterceptor
package com.anson.common.interceptor; import com.anson.common.exception.GlobalExceptionHandler;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; /**
* @description: 拦截器
* @author: anson
* @Date: 2019/12/20 7:23
*/ @Component
public class MyInterceptor implements HandlerInterceptor
{
private static final Logger logger = LoggerFactory.getLogger(MyInterceptor.class); public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception
{
logger.info("afterCompletion被调用");
long startime = (Long) arg0.getAttribute("startime");
logger.info("请求耗时:"+ (System.currentTimeMillis() - startime));
} public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
throws Exception
{
logger.info("postHandle被调用");
} public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception { logger.info("preHandle被调用");
request.setAttribute("startime",System.currentTimeMillis());
return true;
}
}
2)增加配置类AppConfigurer,注册拦截器
package com.anson.config; import com.anson.common.interceptor.MyInterceptor;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; /**
* @description: 配置类
* @author: anson
* @Date: 2019/12/20 7:35
*/
@Configuration
public class AppConfigurer implements WebMvcConfigurer
{
@Autowired
private MyInterceptor myInterceptor; //注册拦截器
@Override
public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(myInterceptor);
}
}
即可
四、后记
过滤器、拦截器、监听器的简单用法就是这样,包括后面要讲的AOP,他们在有些功能上是交叉的,根据实际需要灵活选用即可;
小白的springboot之路(十三)、过滤器、监听器、拦截器的更多相关文章
- springboot环境下配置过滤器和拦截器
以前我们在配置过滤器和拦截器的时候,都是一个类继承一个接口,然后在xml中配置一下就ok 但是,但是,这是springboot的环境,没有xml的配置.所以我们还要继续学习啊啊啊啊啊~~~~~ 先简单 ...
- JavaWeb过滤器.监听器.拦截器-原理&区别-个人总结
对比项 拦截器 过滤器 机制 反射机制 函数回调 是否依赖servlet容器 是 否 请求处理 只能对action请求起作用 几乎所有的请求起作用 对action处理 可以访问action上下文.值栈 ...
- JavaWeb过滤器.监听器.拦截器-原理&区别(转)
1.拦截器是基于java的反射机制的,而过滤器是基于函数回调 2.过滤器依赖与servlet容器,而拦截器不依赖与servlet容器 3.拦截器只能对action请求起作用,而过滤器则可以对几乎所有的 ...
- AOP,过滤器,监听器,拦截器【转载】
面向切面编程(AOP是Aspect Oriented Program的首字母缩写) ,我们知道,面向对象的特点是继承.多态和封装.而封装就要求将功能分散到不同的对象中去,这在软件设计中往往称为职责分配 ...
- JavaWeb过滤器.监听器.拦截器-?原理&区别
过滤器可以简单理解为“取你所想取”,忽视掉那些你不想要的东西:拦截器可以简单理解为“拒你所想拒”,关心你想要拒绝掉哪些东西,比如一个BBS论坛上拦截掉敏感词汇. 1.拦截器是基于java的反射机制,过 ...
- 过滤器 & 监听器 & 拦截器
过滤器: https://blog.csdn.net/MissEel/article/details/79351231 https://blog.csdn.net/qq_32363305/articl ...
- SpringBoot入门教程(十一)过滤器和拦截器
在做web开发的时候,过滤器(Filter)和拦截器(Interceptor)很常见,通俗的讲,过滤器可以简单理解为“取你所想取”,忽视掉那些你不想要的东西:拦截器可以简单理解为“拒你所想拒”,关心你 ...
- springboot配置监听器、过滤器和拦截器
监听器:listener是servlet规范中定义的一种特殊类.用于监听servletContext.HttpSession和servletRequest等域对象的创建和销毁事件.监听域对象的属性发生 ...
- 小白的springboot之路(一)、环境搭建、第一个实例
小白的springboot之路(一).环境搭建.第一个实例 0- 前言 Spring boot + spring cloud + vue 的微服务架构技术栈,那简直是爽得不要不要的,怎么爽法,自行度娘 ...
随机推荐
- 2019-9-28:渗透测试,基础学习,pgp常量,逻辑运算,DNS投毒,笔记
sunny.exe clientid 隧道ID route -n 查看网关netstat -rn 查看网关 DNS劫持ettercap用来内网渗透测试使用,可以嗅探内网,DNS劫持等攻击1,在攻击者电 ...
- cenos7搭建gitlab
git.github和gitlab的区别 git:是一种版本控制系统,是一个命令,是一种工具 gitlib:是基于实现功能的开发库 github:是一个基于git实现的在线代码仓库软件 gitlib可 ...
- day48天jQuary
今日内容 jQuery jQuery引入 下载链接:[jQuery官网](https://jquery.com/),首先需要下载这个jQuery的文件,然后在HTML文件中引入这个文件,就可以使用这个 ...
- Java NIO 三大组件之 Channel
Java NIO 之 Channel 一.什么是Channel Channel用于源节点(例如磁盘)与目的节点的连接,它可以进行读取,写入,映射和读/写文件等操作. 在Java NIO中负责缓冲区中数 ...
- ubuntu 1806 添加 kali 源
最近需要使用 kali 源安装一些软件: 配置 sources.list,根据如下链接:http://mirrors.ustc.edu.cn/help/kali.html 获取 公钥:apt-key ...
- SpringBoot+Vue+WebSocket 实现在线聊天
一.前言 本文将基于 SpringBoot + Vue + WebSocket 实现一个简单的在线聊天功能 页面如下: 在线体验地址:http://www.zhengqingya.com:8101 二 ...
- 小白学 Python 爬虫(12):urllib 基础使用(二)
人生苦短,我用 Python 前文传送门: 小白学 Python 爬虫(1):开篇 小白学 Python 爬虫(2):前置准备(一)基本类库的安装 小白学 Python 爬虫(3):前置准备(二)Li ...
- 如何重置IE浏览器
1.退出所有程序,包括 Internet Explorer.单击“开始”.在“开始搜索”框中键入 inetcpl.cpl 命令,然后按回车键打开“Inetnet 选项”对话框. 2.单击“高级”选项卡 ...
- 从入门到入土:Lambda完整学习指南,包教包会!
什么是Lambda表达式 Lambda表达式是Java SE 8中一个重要的新特性.lambda表达式允许你通过表达式来代替功能接口.lambda表达式就和方法一样,它提供了一个正常的参数列表和一个使 ...
- 谈一谈个人利用Java的mysql的知识完成的数据库的项目-----用户信息管理系统
首先,我先简述一下自己做的过程啊,相信大家来找这样的博客,也都是为了完成自己课程任务吧.我也一样是一名大一的学生,是为了自己的课程任务而开始做数据库的项目的.因为还没学mysql吗,所以是自己找视频啊 ...