美文网首页
Spring Boot AOP实例demo

Spring Boot AOP实例demo

作者: zhglance | 来源:发表于2021-03-26 15:16 被阅读0次

1.项目结构:

项目结构

1.1 基于Aspect的AOP

1.1.1 父pom.xml配置

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.9.RELEASE</version>
    </parent>

    <groupId>com.lance.demo</groupId>
    <artifactId>com-lance-demo</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>pom</packaging>

</project>

1.1.2 module的pom.xml配置

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>com-lance-demo</artifactId>
        <groupId>com.lance.demo</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>com-lance-demo-provider</artifactId>

    <dependencies>

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

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

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

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.11</version>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId> 
        </dependency>

    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

1.1.3 主类:

package com.lance.demo.main;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ComponentScan;

@ComponentScan("com.lance.demo")
@SpringBootApplication
public class SpringBootDemoMain {

    public static void main(String[] args) {
        SpringApplication.run(SpringBootDemoMain.class, args);
    }
}

1.1.4 MyService.java

package com.lance.demo.service;

import com.lance.demo.exception.MyException;
import org.springframework.stereotype.Service;

@Service
public class MyService {

    public int myFunction() {
        System.out.println("MyFunction execute");
        return 0;
    }

    public int myBizFunction() throws MyException {
        System.out.println("myBizFunction execute");
        return 1;
    }
}

1.1.5 MyAspject.java

package com.lance.demo.aop;

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import org.springframework.stereotype.Component;

@Component
@Aspect
public class MyAspect {

    @Pointcut("execution(public * com.lance.demo.service.*.*(..))")
    public void aspect() {
        System.out.println("aspect");
    }

    @Before("aspect()")
    public void doBefore(JoinPoint joinPoint) {
        System.out.println("doBefore:"+ joinPoint.getArgs() +"," + joinPoint.getSignature());
    }

    @After("aspect()")
    public void doAfter(JoinPoint joinPoint) {
        System.out.println("doAfter:"+ joinPoint.getArgs() +"," + joinPoint.getSignature());
    }

    @AfterReturning("aspect()")
    public void doAfterReturning(JoinPoint joinPoint) {
        System.out.println("doAfterReturning:" + joinPoint.getArgs() +"," + joinPoint.getSignature());
    }

    @AfterThrowing(pointcut = "aspect()",throwing = "e")
    public void deAfterThrowing(JoinPoint joinPoint,Throwable e) {
        if(e == null) {
            System.out.println("deAfterThrowing");
        } else {
            System.out.println("deAfterThrowing:" + e);
        }
    }

    @Around("aspect()")
    public Object deAround(ProceedingJoinPoint joinPoint) throws Throwable {
        System.out.println("deAround before");
        Object object = joinPoint.proceed();
        System.out.println("deAround after");
        return object;
    }
}

1.1.6单元测试类MyServiceTest

package com.lance.demo.service;

import com.lance.demo.main.SpringBootDemoMain;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration;

import static org.junit.Assert.*;

@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = SpringBootDemoMain.class)
@WebAppConfiguration
public class MyServiceTest {

    @Autowired
    private MyService myService;

    @Test
    public void myFunction(){
        myService.myFunction();
    }

    @Test
    public void myBizFunction(){
       int result =  myService.myBizFunction();
       System.out.println("result:" + result);
    }
}

1.1.7 输出结果:

deAround before
doBefore:[Ljava.lang.Object;@444cc791,int com.lance.demo.service.MyService.myBizFunction()
myBizFunction execute
doAfterReturning:[Ljava.lang.Object;@444cc791,int com.lance.demo.service.MyService.myBizFunction()
doAfter:[Ljava.lang.Object;@444cc791,int com.lance.demo.service.MyService.myBizFunction()
deAround after
result:1

1.2 ControllerAdvice仅对controller层有效的AOP

1.2.1 MyController.java

package com.lance.demo.controller;

import com.lance.demo.service.MyService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class MyController {

    @Autowired
    private MyService myService;

    @RequestMapping("/hello")
    public String hello() {
        int result = myService.myFunction();
        return "Hello World!" + result;
    }

    @RequestMapping("/biz/hello")
    public String bizHello() {
        int result = myService.myBizFunction();
        return "Hello World!" + result;
    }
}

1.2.2 GlobalExceptionHandler.java

package com.lance.demo.exception;

import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;

@Slf4j
@ControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler(Exception.class)
    @ResponseBody
    public Object exceptionHandler(Exception e) {
        log.error("exceptionHandler error.",e);
        return "Exception";
    }

    @ExceptionHandler(MyException.class)
    @ResponseBody
    public Object myExceptionHandler(Exception e) {
        log.error("myExceptionHandler error.",e);
        return "MyException";
    }
}

1.2.3 自定义异常类MyException.java

package com.lance.demo.exception;

public class MyException extends RuntimeException {

    public MyException(String message) {
        super(message);
    }
}

相关文章

网友评论

      本文标题:Spring Boot AOP实例demo

      本文链接:https://www.haomeiwen.com/subject/copjhltx.html