SpringBoot中怎么使用面向切面编程

发布时间:2021-06-22 16:25:19 作者:Leah
来源:亿速云 阅读:250

这期内容当中小编将会给大家带来有关SpringBoot中怎么使用面向切面编程,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

一、什么是AOP?

AOP,面向切面编程,一句话说明,把一些公共的、和业务无关的功能性代码抽取出来,在运行的时候动态的往业务方法上植入。利用 AOP 可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。

二、AOP常用场景:

  1. 事务开启关闭控制

  2. 日志记录

  3. 权限校验

三、AOP 相关概念介绍:

通知方法的几种类型:

SpringBoot中怎么使用面向切面编程

四、安装配置

Spring Boot 在 Spring 的基础上对 AOP 的配置提供了自动化配置解决方案,我们只需要修改 pom.xml 文件,添加 spring-boot-starter-aop 依赖即可。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-aop</artifactId>
</dependency>

五、编写代码

1、编写controller

@RestController
public class DemoController {
 
    @Autowired
    UserService userService;
 
    @GetMapping("/demo")
    public String demo(Integer id) {
        return userService.getUserById(id);
    }
}

2、编写service

@Service
public class UserService {

   public String getUserById(Integer id) {
       System.out.println("getUserById(" + id + ")...");
       // 等待2秒
       try {
           Thread.sleep(2000);
       }
       catch(InterruptedException e) {
           e.printStackTrace();
       }
       return "piao";
   }

}

3、编写切面

注解说明:

(1)@Aspect 注解:表明这是一个切面类。

(2)@Pointcut 注解:表明这是一个切入点。

(3)@Before 注解:表示这是一个前置通知,该方法在目标方法之前执行。

(4)@After 注解:表示这是一个后置通知,该方法在目标执行之后执行。

(5)@AfterReturning 注解:表示这是一个返回通知,在该方法中可以获取目标方法的返回值。

(6)@AfterThrowing 注解:表示这是一个异常通知,即当目标方法发生异常,该方法会被调用。

(7) @Around 注解:表示这是一个环绕通知。环绕通知是所有通知里功能最为强大的通知,可以实现前置通知、后置通知、异常通知以及返回通知的功能。

@Aspect
@Component
public class LogAspect {

    // 定义一个切入点
    @Pointcut("execution(* com.example.demo.service.*.*(..))")
    public void pc1(){
 
    }
 
    // 前置通知
    @Before(value = "pc1()")
    public void before(JoinPoint jp) {
        String name = jp.getSignature().getName();
        System.out.println(name + "方法开始执行...");
    }
 
    // 后置通知
    @After(value = "pc1()")
    public void after(JoinPoint jp) {
        String name = jp.getSignature().getName();
        System.out.println(name + "方法执行结束...");
    }
 
    // 返回通知
    @AfterReturning(value = "pc1()", returning = "result")
    public void afterReturning(JoinPoint jp, Object result) {
        String name = jp.getSignature().getName();
        System.out.println(name + "方法返回值为:" + result);
    }
 
    // 异常通知
    @AfterThrowing(value = "pc1()", throwing = "e")
    public void afterThrowing(JoinPoint jp, Exception e) {
        String name = jp.getSignature().getName();
        System.out.println(name + "方法抛异常了,异常是:" + e.getMessage());
    }
 
    // 环绕通知
    @Around("pc1()")
    public Object around(ProceedingJoinPoint pjp) throws Throwable {
        String name = pjp.getSignature().getName();
        // 统计方法执行时间
        long start = System.currentTimeMillis();
        Object result = pjp.proceed();
        long end = System.currentTimeMillis();
        System.out.println(name + "方法执行时间为:" + (end - start) + " ms");
        return result;
    }

}

六、验证结果

1、请求接口:http://127.0.0.1:8086/demo

SpringBoot中怎么使用面向切面编程

2、查看控制台信息:

SpringBoot中怎么使用面向切面编程

上述就是小编为大家分享的SpringBoot中怎么使用面向切面编程了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

推荐阅读:
  1. Javascript中怎么实现面向切面编程
  2. SpringBoot中怎么实现aop面向切面编程

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

spring boot

上一篇:Edge中怎么修改默认搜索引擎

下一篇:Spring Boot 中怎么解决跨域请求问题

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》