使用aop拦截自定义注解

场景:第三方调用校验是否有权限,就是常规的校验appId和secret,一个项目中有自己公司服务调用的也有第三方调用的
思路:在第三方调用的方法上添加一个自定义注解,在用aop拦截这个自定义注解

1.先自定义一个注解

@Documented
@Target({ElementType.METHOD})
@Inherited
@Retention(RetentionPolicy.RUNTIME )
public @interface OpenApi {

   /**
    * 开放平台的接口编码
    * @return
    */
   String encode() default "";
}

2.定义aop拦截 有该注解的方法或类(注解应用范围具体看注解的Target配置,OpenApi是应用到方法)

@Aspect
@Order(-1)// 保证该AOP在@Transactional之前执行
@Component
@Slf4j
public class OpenApiAdvice {

    @Autowired
    private IVerifyService iVerifyService;
 

    //调用的方法有该注解才会拦截
    @Pointcut("@annotation(com.cunw.cloud.dataworks.annotation.OpenApi)")
    private void annotationPointCut() {
    }


   //环绕 满足上面的拦截条件就会调用该方法
    @Around("annotationPointCut()")
    public Object annotationAround(ProceedingJoinPoint joinPoint) throws Throwable {
        //获取方法
        Method method = ((MethodSignature) joinPoint.getSignature()).getMethod();

        //得到方法参数  这里是一个数组,因为我这里只有一个参数所以写了[0]
        Object args = joinPoint.getArgs()[0];
       

        // 获取该方法上的 OpenApi注解
        OpenApi aspectAnnotation = method.getAnnotation(OpenApi.class);

        //注解的方法(就是注解里定义的值)
        String encode = aspectAnnotation.encode();


       //写你的业务逻辑

        
        //校验appId,sign等参数
        iVerifyService.verify(args, openApiVO.getSecret());

        //正常往后执行
        return joinPoint.proceed();
    }

}

3. 最后  想想 拦截器和aop有什么区别?

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值