全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

使用spring拦截器实现日志管理实例

使用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小时内与您取得联系。