springboot系列之AOP

本文介绍如何使用SpringBoot实现AOP面向切面编程,通过实战案例演示如何进行全局异常捕获及请求uuid设置等操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

springboot系列之AOP

简介

AOP(Aspect Oriented Programming),即面向切面编程,是Spring框架的大杀器之一。
可以用来做全局异常捕获,请求uuid等等

直接上代码

  • 添加依赖
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-aop</artifactId>
		</dependency>
  • 实战代码
@Aspect
@Component
public class AopController {

    private static final Logger logger = LoggerFactory.getLogger(AopController.class);
    ThreadLocal<Long> start = new ThreadLocal<>();

    /**
     * 定义一个切点
     */
    @Pointcut("execution(public * com.example.springredis.action.*.*(..))")
    public void handlerMethod() {
    }

    /**
     * 环绕执行
     * @param pjp
     * @return
     */

    @Around("handlerMethod()")
    public Object handlerPageResultBeanMethod(ProceedingJoinPoint pjp) {
        ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
        //获取请求request
        HttpServletRequest request = requestAttributes.getRequest();
        //获取请求response
        HttpServletResponse response = requestAttributes.getResponse();
        //获取请求路径名
        String declaringTypeName = pjp.getSignature().getDeclaringTypeName();
        System.out.println("路径"+declaringTypeName);
        //获取请求方法名
        String name = pjp.getSignature().getName();
        System.out.println("方法名"+name);
        start.set(System.currentTimeMillis());
        Object proceed =null;
        try {
            proceed = pjp.proceed();
            logger.info(pjp.getSignature() + " 方法执行耗时:" + (System.currentTimeMillis() - start.get()));
        } catch (Throwable e) {
        }

        return proceed;
    }
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值