關于aop切面 注解、參數如何獲取
更新時間:2022年01月11日 09:38:53 作者:筏鏡
這篇文章主要介紹了關于aop切面 注解、參數如何獲取,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教。
aop切面 注解、參數如何獲取
在工作中會經常使用aop,這里將aop使用基本方法,獲取在切點中使用的獲取參數、注解做一個樣例。
定義需要切面的注解
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface AnnDemo {
? ? String value();
? ? boolean isAop() default true;
}在需要進行切面的方法標注注解
@RestController
@RequestMapping("/order")
public class OrderController {
? ? @Autowired
? ? private OrderService orderService;
? ? @RequestMapping("/all")
? ? @AnnDemo(value = "all",isAop = false)
? ? public List<TbOrder> findAll() {
? ? ? ? List<TbOrder> list = orderService.getOrderList();
? ? ? ? return list;
? ? }
? ? @RequestMapping("/page")
? ? @AnnDemo(value = "page")
? ? public List<TbOrder> findPage(@RequestParam("username") String username) {
? ? ? ? List<TbOrder> listPage = orderService.getOrdersListPage();
? ? ? ? return listPage;
? ? }
}定義切面
在切面中獲取切點注解,方法,參數的獲取
@Aspect
@Component
public class AspectDemo {
@Pointcut(value = "execution(* com.yin.freemakeradd.controller..*(..))")
public void excetionMethod() {}
@Pointcut(value = "execution(* com.yin.freemakeradd.controller..*(..)) && @annotation(AnnDemo)")
public void excetionNote() { }
@Before("excetionMethod()")
public void testBefore(JoinPoint joinPoint) {
System.out.println("----------------------------前置通知---");
Object[] args = joinPoint.getArgs();
for (Object arg : args) {
System.out.println(arg);
}
}
@Around(value = "execution(* com.yin.freemakeradd.controller..*(..)) && @annotation(AnnDemo)")
public Object testBeforeNote(ProceedingJoinPoint joinPoint) throws Throwable {
//用的最多通知的簽名
Signature signature = joinPoint.getSignature();
MethodSignature msg=(MethodSignature) signature;
Object target = joinPoint.getTarget();
//獲取注解標注的方法
Method method = target.getClass().getMethod(msg.getName(), msg.getParameterTypes());
//通過方法獲取注解
AnnDemo annotation = method.getAnnotation(AnnDemo.class);
Object proceed;
//獲取參數
Object[] args = joinPoint.getArgs();
System.out.println(annotation.value());
System.out.println(annotation.isAop());
for (Object arg : args) {
System.out.println(arg);
}
if (Objects.isNull(annotation) || !annotation.isAop()) {
System.out.println("無需處理");
proceed = joinPoint.proceed();
}else {
System.out.println("進入aop判斷");
proceed = joinPoint.proceed();
if(proceed instanceof List){
List proceedLst = (List) proceed;
if(!CollectionUtils.isEmpty(proceedLst)){
TbOrder tbOrder = new TbOrder();
tbOrder.setPaymentType("fffffffffffffffffff");
ArrayList<TbOrder> tbOrderLst = new ArrayList<>();
tbOrderLst.add(tbOrder);
return tbOrderLst;
}
}
System.out.println(proceed);
}
return proceed;
}
}
aop中獲取自定義注解的屬性值
自定義注解
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface SystemLog {
?
?? ?public String description() default "";
}用在方法上
@ResponseBody
@ValidRequestBody
@RequestMapping("/login")
@SystemLog(description="登錄")
public GlobalResponse login(@RequestBody @Valid User user, BindingResult bindingResult){
? ? ......
}獲取注解的屬性值
@Around("@annotation(com.xxx.xxx.xxx.SystemLog)")
public Object around(ProceedingJoinPoint joinPoint) throws Throwable{
? ? SystemLog systemLog = ((MethodSignature)joinPoint.getSignature()).getMethod().getAnnotation(SystemLog.class); ? ?
? ? ......
}以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
常用校驗注解之@NotNull,@NotBlank,@NotEmpty的區(qū)別及說明
這篇文章主要介紹了常用校驗注解之@NotNull,@NotBlank,@NotEmpty的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01

