aop切面获取方法参数,注解,及判断是否成功执行

项目中第一次用到自定义注解,这里简单记一下,以方便以后忘了来回顾一下

自定义注解

/**
 * 修改方法日志注解
 */
@Target(ElementType.METHOD)
@Documented
@Retention(RetentionPolicy.RUNTIME)
public @interface EditLog {
    String logDesc();
}

切面类

@Component
@Aspect
public class EditLogAspect {
    @Autowired
    private MongoTemplate mongoTemplate;


    @Pointcut("@annotation(xx.xx.xx.EditLog)")//切入带有此注解的方法
    public void controllerAspect() {

    }
@Around(value = "controllerAspect()")
    public Object around(ProceedingJoinPoint pjp) throws Throwable {
        System.out.println("进入切面");
        Object[] args =  pjp.getArgs();//获取参数
        System.out.println(args[0].toString());
        //方法执行之前查一次数据库
        Object o= pjp.proceed();
        //方法执行后查一次数据库
        JSONObject resultJson = (JSONObject) JSON.toJSON(o);
        HttpStatus code = resultJson.getObject("code", HttpStatus.class);//自己封装了统一的返回对象,对象中包含状态码,在这里获取
        if (code.is2xxSuccessful()) {
            System.out.println("成功");
            Signature sig = pjp.getSignature();
            MethodSignature msig =(MethodSignature) sig;
            Object target = pjp.getTarget();
            Method method = target.getClass().getMethod(msig.getName(), msig.getParameterTypes());
            //得到方法上此注解的信息
        	String logDesc = method.getAnnotation(EditLog.class).logDesc();
            System.out.println(logDesc);
            }
      }      
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
获取注解中自定义的值,可以使用反射的方式获取注解对象,并调用注解对象的方法获取值。具体步骤如下: 1. 定义一个自定义注解,例如 @MyAnnotation,并在注解中添加自定义属性,例如 value。 2. 在需要使用注解的地方(例如方法、类、参数等)上添加 @MyAnnotation 注解,并设置属性值。 3. 定义一个切面类,使用 @Aspect 注解标记类为切面,并在需要拦截的方法上添加切点表达式,例如 @Around。 4. 在切面方法中,通过 JoinPoint 获取目标方法,然后使用反射获取方法上的注解,从而获取注解中的属性值。 示例代码如下: ```java @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface MyAnnotation { String value(); } @Aspect @Component public class MyAspect { @Around("@annotation(com.example.MyAnnotation)") public Object around(ProceedingJoinPoint point) throws Throwable { MethodSignature signature = (MethodSignature) point.getSignature(); Method method = signature.getMethod(); MyAnnotation annotation = method.getAnnotation(MyAnnotation.class); String value = annotation.value(); // TODO: 处理注解值 return point.proceed(); } } @Controller public class UserController { @GetMapping("/users/{id}") @MyAnnotation("user_id") public String getUser(@PathVariable Long id) { // ... } } ``` 在上面的示例中,我们定义了一个 @MyAnnotation 注解,并在注解中添加了一个 value 属性。我们在 UserController 的 getUser 方法上添加了 @MyAnnotation 注解,并设置了 value 属性为 "user_id"。 然后,在 MyAspect 类中,我们定义了一个切面方法,使用 @Around 注解指定需要拦截的方法,并使用 @annotation(com.example.MyAnnotation) 表达式获取被 @MyAnnotation 注解修饰的方法。我们通过反射获取方法上的注解,并调用注解对象的 value() 方法获取 value 属性的值,最终可以进行处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值