今天正好在写一个自定义鉴权的包,是利用AOP实现的,其中我定义了两个注解,一个是@Authorize
,作用是标记该接口或该控制层是需要什么身份、权限才可以访问。一个是@Anonymous
,作用是标记该接口或该控制层是否可以匿名访问(跳过鉴权、登陆验证)。那么所以我就必须要获取到方法上与类上我所定义的注解。
获取方法上的注解
先通过ProceedingJoinPoint
对象的proceedingJoinPoint.getSignature()
方法获取到Signature
的对象,然后再强制类型转换((MethodSignature)signature
)为一个MethodSignature
对象,通过signature.getMethod()
方法获取到一个Method
对象,最后通过getAnnotation(Class<T>)
方法获取到你要获取的注解,也可以通过method.getAnnotations()
方法获取到这个当前拦截的方法上所有的注解。
private Object authHandler(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {
Signature signature = proceedingJoinPoint.getSignature();
MethodSignature methodSignature = (MethodSignature) signature;
Method method = methodSignature.getMethod();
Authorize authorizeAnnotation = method.getAnnotation(Authorize.class);
// 业务代码
....
return point.proceed();
}
获取拦截的类上的注解
如下方代码,通过反射直接去获取到即可。
private Object authHandler(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {
proceedingJoinPoint.getTarget().getClass().getAnnotation(Anonymous.class);
// 业务代码
....
return point.proceed();
}