栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

SpringAop小案例

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SpringAop小案例

一.我们需要添加依赖

    org.springframework.boot
    spring-boot-starter-aop

二. 创建一个切面类,并使用@Aspect和@Component注解修饰,在类里添加一个方法,这个方法就是你想要执行的方法.在方法上添加切入点,使用@Pointcut注解.
@Aspect
@Component
public class LogAspect {
    //注解表达式切入点
    @Pointcut("@annotation()")
    public void doLog(){}

}

三.自定义一个注解.
@Target(ElementType.METHOD)//注解可以加在哪里
@Retention(RetentionPolicy.RUNTIME)//注解合适生效
public @interface RequiredLog {
    String value() default "";
}

注解创建完成后,可以在切入点里加入这个注解所在的包路径,并添加一个通知.

@Slf4j
@Aspect
@Component
public class LogAspect {
    //注解表达式切入点
    @Pointcut("@annotation(com.jt.resource.annotation.RequiredLog)")
    public void doLog(){}//注解描述的方法

    
    @Around("doLog()")
    public Object doAround(ProceedingJoinPoint joinPoint) throws Throwable {
        log.debug("Before {}",System.currentTimeMillis());//{}表示占位符,
        Object result = joinPoint.proceed();//执行链(其他切面,目标方法)
        log.debug("After {}",System.currentTimeMillis());
        return result;//目标方法(切入点方法)的执行结果
    }

}
四. 最后在你需要添加的扩展业务的方法上添加自定义的注解,我这边是加载controller层的方法里面
//将RequiredLog注解描述的方法作为切入点方法,在方法执行之前和之后进行日志记录
    @RequiredLog("文件上传日志")//扩展业务--日志
    @PostMapping("/upload")//核心业务
    public String uploadFile(MultipartFile uploadFile) throws IOException {
        //1.创建文件存储目录(格式:yyyy/MM/dd)
        //ofPattern()方法设置格式,
        //1.1获取当前时间目录
        String dateDir = DateTimeFormatter.ofPattern("yyyy/MM/dd").format(LocalDate.now());
        //1.2构建目录文件对象
        File uploadFileDir = new File(resourcePath,dateDir);
        if (!uploadFileDir.exists())uploadFileDir.mkdirs();

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/657755.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号