使用HandlerInterceptor拦截器,可以拦截请求,实现通用的日志管理操作

一、添加拦截器类
在"src/main/java"代码文件夹的"org.xs.demo1"的包下新建"LogInterceptor.java"类:
package org.xs.demo1;
import java.text.SimpleDateFormat;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.core.NamedThreadLocal;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
/**
* 日志拦截器
* @author ThinkGem
*/
public class LogInterceptor implements HandlerInterceptor {
private final Logger log = LoggerFactory.getLogger(getClass().getName());
private static final ThreadLocal<Long> startTimeThreadLocal = new NamedThreadLocal<Long>("ThreadLocal StartTime");
/**
* 预处理
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
long beginTime = System.currentTimeMillis(); //开始时间
startTimeThreadLocal.set(beginTime); //线程绑定变量(该数据只有当前请求的线程可见)
log.info("开始计时: {}", new SimpleDateFormat("hh:mm:ss.SSS").format(beginTime));
return true;
}
/**
* 返回处理
*/
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
if (modelAndView != null){
log.info("ViewName: " + modelAndView.getViewName());
}
}
/**
* 后处理
*/
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
// 保存日志
//LogUtils.saveLog(request, handler, ex, null);
// 输出日志信息
log.info("访问地址:" + request.getRequestURI() + ",执行方式:" + request.getMethod());
long beginTime = startTimeThreadLocal.get(); //得到线程绑定的局部变量(开始时间)
long endTime = System.currentTimeMillis(); //结束时间
log.info("计时结束:{}", new SimpleDateFormat("hh:mm:ss.SSS").format(endTime));
}
}
二、修改配置文件
修改spring-mvc.xml件,加入:
<!-- 拦截器配置 -->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**" />
<bean class="org.xs.demo1.LogInterceptor" />
</mvc:interceptor>
</mvc:interceptors>
三、运行测试
访问"http://localhost:8080/demo1/hello/list2"地址
可以看到拦截器中输出的日志信息了
实例代码地址:spring-HandlerInterceptor_jb51.rar
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# spring
# 日志拦截器
# springmvc
# Springboot+redis+Interceptor+自定义annotation实现接口自动幂等
# SpringMVC拦截器——实现登录验证拦截器的示例代码
# SpringMVC拦截器实现登录认证
# 使用Spring方法拦截器MethodInterceptor
# 拦截器
# 绑定
# 可以看到
# 配置文件
# 大家多多
# 后处理
# 器中
# 结束时间
# ThinkGem
# LoggerFactory
# public
# web
# Logger
# core
# NamedThreadLocal
# springframework
# author
# ModelAndView
# implements
# lt
相关文章:
郑州企业网站制作公司,郑州招聘网站有哪些?
如何通过FTP空间快速搭建安全高效网站?
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
如何快速搭建高效服务器建站系统?
建站VPS配置与SEO优化指南:关键词排名提升策略
制作证书网站有哪些,全国城建培训中心证书查询官网?
,想在网上投简历,哪几个网站比较好?
nginx修改上传文件大小限制的方法
如何快速生成凡客建站的专业级图册?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
相册网站制作软件,图片上的网址怎么复制?
已有域名如何快速搭建专属网站?
C#怎么使用委托和事件 C# delegate与event编程方法
如何通过远程VPS快速搭建个人网站?
简历在线制作网站免费版,如何创建个人简历?
装修招标网站设计制作流程,装修招标流程?
公司网站制作费用多少,为公司建立一个网站需要哪些费用?
如何在宝塔面板创建新站点?
如何选择PHP开源工具快速搭建网站?
如何在阿里云虚拟服务器快速搭建网站?
如何通过免费商城建站系统源码自定义网站主题与功能?
如何选择可靠的免备案建站服务器?
东莞专业制作网站的公司,东莞大学生网的网址是什么?
如何高效完成自助建站业务培训?
建站之星如何助力网站排名飙升?揭秘高效技巧
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
江苏网站制作公司有哪些,江苏书法考级官方网站?
Swift中switch语句区间和元组模式匹配
电脑免费海报制作网站推荐,招聘海报哪个网站多?
教程网站设计制作软件,怎么创建自己的一个网站?
如何通过商城自助建站源码实现零基础高效建站?
如何高效完成独享虚拟主机建站?
赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?
如何正确下载安装西数主机建站助手?
jQuery 常见小例汇总
网站制作大概多少钱一个,做一个平台网站大概多少钱?
如何通过虚拟主机空间快速建站?
建站主机服务器选购指南:轻量应用与VPS配置解析
企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?
已有域名和空间,如何快速搭建网站?
免费视频制作网站,更新又快又好的免费电影网站?
如何高效利用200m空间完成建站?
如何通过西部数码建站助手快速创建专业网站?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
如何撰写建站申请书?关键要点有哪些?
内网网站制作软件,内网的网站如何发布到外网?
建站之星导航配置指南:自助建站与SEO优化全解析
C++中引用和指针有什么区别?(代码说明)
西安专业网站制作公司有哪些,陕西省建行官方网站?
清除minerd进程的简单方法
*请认真填写需求信息,我们会在24小时内与您取得联系。