一 .定义自定义注解
@Documented
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface LoginUser{
}
二.导入的依赖包
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>5.2.8.RELEASE</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.9.6</version>
</dependency>
三.实现环绕注解
package com.qf.annotation.impl;
import com.qf.annotation.LoginUser;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;
@Aspect
@Component
public class LoginUserImpl {
@Around("@annotation(loginUser)")
public void parseToken( ProceedingJoinPoint point,LoginUser loginUser) {
System.out.println("loginUser = [" + loginUser + "]");
try {
Object proceed = point.proceed();
System.out.println("proceed = " + proceed);
} catch (Throwable throwable) {
throwable.printStackTrace();
}
}
}
需要注意点
- 使用该的注解时,必须在启动类进行包扫描,如果同一个模块则无需
- LoginUser 参数一定要写在最后面否则会报非法参数异常
