AOP的简单使用

  • AOP 的核心其实就是动态代理,可以使用 JDK 的动态代理,也可以使用 CGLIB 代理,主要应用于一些具有横切性质的系统级服务,如日志收集、事务管理、安全检查、缓存、对象池管理等。
    比如在 SpringBoot 项目中,如何利用 AOP 打印接口的入参和出参日志,以及执行时间:
    第一步引⼊入依赖:引⼊入 AOP 依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>

第二步,自定义注解:自定义一个注解作为切点:

@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD})
@Documented
public @interface WebLog {
}

第三步:配置 AOP 切面:

  • @Aspect:标识切面
  • @Pointcut:设置切点,这里以自定义注解为切点
  • @Around:环绕切点,打印方法签名和执行时间
@Aspect
@Component
public class WebLogAspect {
private final static Logger logger =
LoggerFactory.getLogger(WebLogAspect.class);
/**
* 以⾃自定义 @WebLog 注解为切点
**/
@Pointcut("@annotation(cn.fighter3.spring.aop_demo.WebLog)")
public void webLog() {}
/**
* 在切点之前织⼊入
*/
@Before("webLog()")
public void doBefore(JoinPoint joinPoint) throws Throwable {
// 开始打印请求⽇日志
ServletRequestAttributes attributes = (ServletRequestAttributes)
RequestContextHolder.getRequestAttributes();
HttpServletRequest request = attributes.getRequest();
// 打印请求相关参数
logger.info("========================================== Start
==========================================");
// 打印请求 url
logger.info("URL : {}", request.getRequestURL().toString());
// 打印 Http method
logger.info("HTTP Method : {}", request.getMethod());
// 打印调⽤用 controller 的全路路径以及执⾏行行⽅方法
logger.info("Class Method : {}.{}",
joinPoint.getSignature().getDeclaringTypeName(),
joinPoint.getSignature().getName());
// 打印请求的 IP
logger.info("IP : {}", request.getRemoteAddr());
// 打印请求⼊入参
logger.info("Request Args : {}",new
ObjectMapper().writeValueAsString(joinPoint.getArgs()));
}
/**
* 在切点之后织⼊入
* @throws Throwable
*/
@After("webLog()")
public void doAfter() throws Throwable {
// 结束后打个分隔线,⽅方便便查看
logger.info("=========================================== End
===========================================");
}
/**
* 环绕
*/
@Around("webLog()")
public Object doAround(ProceedingJoinPoint proceedingJoinPoint) throws
Throwable {
//开始时间
long startTime = System.currentTimeMillis();
Object result = proceedingJoinPoint.proceed();
// 打印出参
logger.info("Response Args : {}", new
ObjectMapper().writeValueAsString(result));
// 执⾏行行耗时
logger.info("Time-Consuming : {} ms", System.currentTimeMillis() -
startTime);
return result;
}
}


第四步:使用:只需要在接口上加上自定义注解

@GetMapping("/hello")
@WebLog(desc = "这是⼀一个欢迎接⼝口")
public String hello(String name){
return "Hello "+name;
}

第五步:执行结果:可以看到日志打印了入参、出参和执行时间

在这里插入图片描述

  • 9
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值