springboot切面logdemo

简介: `LogAspect` 类为一个 Spring AOP 切面,用于日志记录。它拦截 `com.mryan.aop_mylog.controller` 包下的所有方法调用。方法入参和出参信息会被记录,异常情况也会被捕获并处理。代码使用了 `@Around` 注解进行环绕通知,并通过 ` ProceedingJoinPoint` 获取方法信息。日志通过 `Logger.getLogger(LogAspect.class)` 进行输出。

 

package com.mryan.aop_mylog.utils;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.Signature;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.reflect.MethodSignature;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.UUID;
import java.util.logging.Logger;
@Aspect
@Component
public class LogAspect {
    private static Logger log = Logger.getLogger("LogAspect.class");
    @Around("execution(* com.mryan.aop_mylog.controller..*.*(..))")
    @ResponseBody
    public Object logAround(ProceedingJoinPoint joinPoint) throws Exception {
        String uuid = UUID.randomUUID().toString();//用于串联起来出入日志 防止并发混乱
        Object result = null;
        String className = joinPoint.getTarget().getClass().getSimpleName();
        Signature signature = joinPoint.getSignature();
        MethodSignature methodSignature = (MethodSignature) signature;
        String methodName = methodSignature.getName();
        StringBuilder paramInSb = null;
        StringBuilder paramOutSb = null;
        Object[] args = joinPoint.getArgs();
        if (args.length > 0) {
            paramInSb = new StringBuilder();
            String[] argNames = methodSignature.getParameterNames();
            paramInSb.append(className).append(".").append(methodName).append("-->").append(uuid).append("入参---->");
            for (int i = 0; i < argNames.length; i++) {
                if ((!(args[i] instanceof MultipartFile)) && (!(args[i] instanceof HttpServletRequest)) && (!(args[i] instanceof HttpServletResponse) && (!(args[i] instanceof MultipartFile[])))) {
                    paramInSb.append(argNames[i]).append(":");
//                            append(JSON.toJSONString(args[i]));
                }
            }
            log.info(paramInSb.toString());
        }
        try {
            result = joinPoint.proceed();
            paramOutSb = new StringBuilder();
            paramOutSb.append(className).append(".").append(methodName).append("-->").append(uuid).append("出参:");
//                    .append(JSON.toJSONString(result));
            log.info(paramOutSb.toString());
        } catch (Exception e) {
//            log.error("Log-->方法执行异常");
            throw e;
        } catch (Throwable throwable) {
//            log.error("Log-->方法执行错误", throwable);
//            throw new Exception(ResponseCode.FAILURE, "未知错误");
        }
        return result;
    }
}

image.gif


目录
相关文章
|
6天前
|
Java Spring
Springboot中Aop的使用
Springboot中Aop的使用
|
6天前
|
Java
SpringBoot常用注解
SpringBoot常用注解
16 0
|
10月前
|
XML 缓存 运维
springboot注解(全)
springboot注解(全)
120 0
|
6天前
|
存储 JSON Java
Springboot注解总结
Springboot注解总结
|
6天前
|
XML Java 数据库
SpringBoot注解总结
SpringBoot注解总结
16 1
|
6天前
|
Java 数据库 数据格式
springboot常用注解
springboot常用注解,超全,超详细
springboot常用注解
|
9月前
|
XML Java 数据格式
SpringBoot-32-常用注解汇总2
SpringBoot-32-常用注解汇总2 在上一章节我们已经讲解了SpringBoot中Controller相关注解,没有看的可以了解一下SpringBoot-31-Controller相关注解详解
52 0
|
Java Spring 容器
40 个 SpringBoot 常用注解 中
40 个 SpringBoot 常用注解 中
89 0
40 个 SpringBoot 常用注解  中
|
前端开发 Java 索引
40 个 SpringBoot 常用注解 上
40 个 SpringBoot 常用注解 上
89 0
40 个 SpringBoot 常用注解   上
|
XML JSON 负载均衡