springboot最新版本自定义日志注解和AOP

LogAspectAnnotation

@ControllerLogAspectAnnotation

/**
 * 
 * Define a log facet annotation
 * @author sunyang
 * @date 2018/12/19 14:23
 */

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE, ElementType.ANNOTATION_TYPE, ElementType.METHOD})
public @interface ControllerLogAspectAnnotation {
    //Description
    String description() default "";

    //Print request paramters
    boolean isPrintPostData() default true;

    //Print response Results
    boolean isPrintResultData() default true;

    //Print exceptions
    boolean isPrintThrowing() default true;

    //Print consumption time
    boolean isPrintSpendTime() default false;

    //Default value
    String value() default "";

}

AbstractControllerLogAspect

com.sunyk.annotation.AbstractControllerLogAspect

/**
 * Define abstract class log slices
 *
 * @author sunyang
 * @date 2018/12/19 14:30
 */
public abstract class AbstractControllerLogAspect {

    private static final Logger log = LoggerFactory.getLogger(AbstractControllerLogAspect.class);

    public AbstractControllerLogAspect() {
    }

    //Define an abstract method
    public abstract void controllerLog();

    //Logic processing before operation
    @Before("controllerLog() && @annotation(controllerLogAspectAnnotation)")
    public void doBefore(JoinPoint joinPoint, ControllerLogAspectAnnotation controllerLogAspectAnnotation) throws Throwable{
        if (controllerLogAspectAnnotation.isPrintPostData()){
            log.info(controllerLogAspectAnnotation.description() + "开始调用:" + "requestData = {}", joinPoint.getArgs());
        }

    }
}

ControllerLogAspect

com.sunyk.aop.ControllerLogAspect

/**
 * 
 * Using AOP to define aspect components, and used for annotation such as 
 * @ControllerLogAspectAnnotation. 
 * From the AbstractColltrollerLogAspect class.
 * 
 * @author sunyang
 * @date 2018/12/19 15:07
 */

@Aspect
@Component
@Configuration
public class ControllerLogAspect  extends AbstractControllerLogAspect{
    @Override
    @Pointcut("execution(* com.sunyk.*.controller.*Controller.*(..))")
    public void controllerLog() {
    }
}

ServiceMonitor

com.sunyk.aop.ServiceMonitor

/**
 * Use AOP alone to define aspect scan components
 * @author sunyang
 * @date 2018/12/19 18:39
 */
@Aspect
@Component
public class ServiceMonitor {

    @AfterReturning("execution(* com.sunyk.*.controller.UseWebFluxController.useLog())")
    public void logServiceAccess(JoinPoint joinPoint){
        System.out.println("Completed:" + joinPoint);
    }
}

Test

com.sunyk.flux.controller.UseWebFluxController

/**
 * @author sunyang
 * @date 2018/12/19 14:40
 */
@RestController
public class UseWebFluxController {

    @GetMapping("/")
    @ControllerLogAspectAnnotation(description = "start...", isPrintPostData = true)
    public String useLog(){
        System.out.println("use log....");
        return null;
    }
}

Effect Diagram

1545287858622

Other

pom.xml dependencies

<dependencies>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-actuator</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-webflux</artifactId>
		</dependency>

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
		<dependency>
			<groupId>io.projectreactor</groupId>
			<artifactId>reactor-test</artifactId>
			<scope>test</scope>
		</dependency>
	</dependencies>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值