SpringMVC日志记录(注解版)

SpringMVC日志记录(注解版)
不会注解版配置的可以看
https://blog.csdn.net/qq_73296527/article/details/134621565

1、导入依赖

 <dependencies>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-webmvc</artifactId>
      <version>5.3.8</version>
    </dependency>

    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>javax.servlet-api</artifactId>
      <version>4.0.1</version>
    </dependency>

    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.12</version>
      <scope>test</scope>
    </dependency>

    <dependency>
      <groupId>commons-io</groupId>
      <artifactId>commons-io</artifactId>
      <version>2.4</version>
    </dependency>

  </dependencies>

一定要记得刷新依赖

2、在Java包下建立一个interceptor包里面在建立一个LogInterceptor类

package interceptor;

import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;

public class LogInterceptor implements HandlerInterceptor {
    private static final String LOG_FILE_PATH = "D://Maven-workspace-idea//demo//logs.txt";

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 记录访问时间
        long startTime = System.currentTimeMillis();
        // 存入request对象
        request.setAttribute("startTime", startTime);
        // 记录Controller的路径和方法
        String controllerPath = request.getRequestURI().split("\\?")[0];
        // 获取handler对象的方法和名称
        String methodName = ((HandlerMethod) handler).getMethod().getName();
        writeLog("访问时间:" + new java.util.Date() + ",Controller的路径:" + controllerPath + ",对应的方法名称:" + methodName);
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        //记录请求参数和请求相对路径
        String requestParams = request.getQueryString();// 获取查询字符串,请求的参数信息
        // 获取URI,并且去除上下文路径,保留相对路径
        String rPath = request.getRequestURI().substring(request.getContextPath().length());
        writeLog("请求参数为:" + requestParams + ",请求相对路径:" + rPath);
        // 请求处理时长
        long endTime = System.currentTimeMillis();
        long startTime = (Long) request.getAttribute("startTime");
        long cTime = endTime - startTime;
        writeLog("请求处理时长为:" + cTime + "ms");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        // 记录响应结果和失败原因
        int statusCode = response.getStatus();// 获取状态码
        String result = statusCode >= 200 && statusCode < 300 ? "成功" : "失败";
        writeLog("响应状态码:" + statusCode + ",响应结果:" + result);
        if (ex != null) {
            writeLog("失败原因:" + ex.getMessage());
        } else {
            writeLog("响应成功:OK!");
        }
    }

    private synchronized void writeLog(String log) {
        try (PrintWriter writer = new PrintWriter(new FileWriter(LOG_FILE_PATH, true))) {
            writer.println(log);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

说明:

  • private static final String LOG_FILE_PATH = "D://Maven-workspace-idea//demo//logs.txt";
    声明了一个私有的静态常量LOG_FILE_PATH,用于存储日志文件的路径。(这个路径写你们自己想要放入的地方)
  • private synchronized void writeLog(String log)
    声明了一个私有的同步方法writeLog,用于将日志信息写入日志文件。
  • try (PrintWriter writer = new PrintWriter(new FileWriter(LOG_FILE_PATH, true))) { writer.println(log); }
    使用PrintWriter将日志信息写入到指定的日志文件中。
  • catch (IOException e) { e.printStackTrace(); }
    捕获可能发生的IOException异常并打印堆栈信息。

3、ServletContainersInitConfig里面写一个

在这里插入图片描述
在这里插入图片描述

package config;

import interceptor.LogInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import org.springframework.web.servlet.view.InternalResourceViewResolver;

@Configuration
@EnableWebMvc
@ComponentScan("controller")
public class SpringMvcConfig implements WebMvcConfigurer {
    @Bean
    public InternalResourceViewResolver internalResourceViewResolver(){
        InternalResourceViewResolver viewResolver = new InternalResourceViewResolver();
        viewResolver.setPrefix("/WEB-INF/");
        viewResolver.setSuffix(".jsp");
        return viewResolver;
    }

   @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new LogInterceptor()).addPathPatterns("/**");
    }

}

这段代码的作用是向拦截器注册表中添加一个名为LogInterceptor的拦截器,并指定该拦截器对所有的请求路径都生效(通过addPathPatterns(“/**”)方法)。这意味着LogInterceptor将会拦截所有进入应用程序的请求,并执行其中定义的逻辑。

4、在 controller里面写一个HelloController 的方法

package controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class HelloController {

    @RequestMapping("/hello")
    public String hello(){
        return "hello";
    }

}


5、运行tomcat

在这里插入图片描述
然后再你存放日志的目录下面就可以看见这个请求的日志信息了
在这里插入图片描述

(可以根据你们自己的需求在LogInterceptor类里面进行设计)

  • 18
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值