• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Java SpringBoot实现AOP

springboot 搞代码 4年前 (2022-01-09) 21次浏览 已收录 0个评论
文章目录[隐藏]

1、AOP基本总结

连接点JoinPoint):

连接点是程序运行的某个阶段点,如方法调用、异常抛出等

切入点Pointcut):

切入点是JoinPoint的集合
是程序中需要注入Advice的位置的集合,即Advice在什么条件下才能被触发

增强Advisor):

增强是切入点PointcutAdvice的综合体,即在连接点JoinPoint上执行的行为
通过JDK/CGLIB代理模式实现AOP

切面Aspect):

@Aspect通常是一个类的注解,通常与@Component搭配使用

AOP代理AOP Proxy):

AOP使用动态代理模式创建对象,从而实现在连接点JoinPoint处插入增强
其中JDK本文来源gao@!dai!ma.com搞$$代^@码网*只能代理接口,CGLIB基于子类但不能代理final类

2、常用方法

3、增强类型

  • @Before:前置增强,在某个JoinPoint执行前的增强
  • @After:final增强,不管抛异常还是正常退出都执行的增强
  • @AfterReturning:后置增强,方法正常退出时执行
  • @AfterThrowing:异常抛出增强,抛出异常后执行
  • @Around:环绕增强,包围一个连接点的增强,最强大的一个方式,且常用

4、示例说明

学了一下AOP的使用,写了个@Arounddemo,将几个查询操作存入数据库作为Log并且定时清理过期数据

本人的Demo用的是Dubbo框架,而AOP的示例写在了Provider中,大概结构如下:

monitor:

  • annotation:注解类
  • aop:切面的定义及实现
  • impl:UserAopTask接口的实现类

 1)UserLog实体类

@Data
@ToString
@NoArgsConstructor
@AllArgsConstructor
public class UserLog implements Serializable {
    private Integer id;
    private String methodName;
    private String methodArgs;
    private String classFullName;
    private String className;
    private Date invokeTime;
    private Double costTime;
}
 

2)LogTaskMapper对应mapper接口

public interface LogTaskMapper {
    /**
     * TEST AOP INSERT INFO INTO TABLE
     * @param userLog
     */
    void insertUserLog(UserLog userLog);

    /**
     * DELETE LOGS IN TABLE LAST x MINUTES
     * @param minutes
     */
    void deleteUserLog(int minutes);
}
 

3)UserAopTask接口

public interface UserAopTask {
    void insertUserLog(UserLog log);
}
 


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Java SpringBoot实现AOP

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址