aop或拦截器获取鉴权注解信息

本文介绍了如何在SpringBoot项目中使用AOP和拦截器的方式,通过RolePermission注解来实现对控制器方法的权限检查。AOP方式利用AspectJ进行切面编程,拦截带有RolePermission注解的方法;拦截器方式则作为HandlerInterceptor实现预处理阶段的权限验证。
摘要由CSDN通过智能技术生成

 1. AOP方式

package com.dj.springboot.study.aspect;

import com.dj.springboot.study.annotation.RolePermission;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.aspectj.lang.reflect.MethodSignature;
import org.springframework.core.annotation.AnnotationUtils;
import org.springframework.stereotype.Component;

/**
 * @Author: ldj
 * @Date: 2024/02/20/14:38
 * @Description: AOP实现获取鉴权注解
 */
@Aspect
@Component
public class PermissionAspect {

    //忽略
    @Pointcut("execution(* com.xxx.yyy.controller.*.*(..))")
    public void pointcut1(){
    }

    @Pointcut("@annotation(com.xxx.yyy.annotation.RolePermission)")
    public void pointcut2(){
    }

    @Around("pointcut2()")
    public Object doAround(ProceedingJoinPoint joinPoint) throws Throwable {
        Object[] args = joinPoint.getArgs();
        MethodSignature signature = (MethodSignature) joinPoint.getSignature();
        //1.获取目标类上的目标注解(可判断目标类是否存在该注解)
        RolePermission annotation = AnnotationUtils.findAnnotation(signature.getClass(), RolePermission.class);
        //2.获取目标方法上的目标注解(可判断目标方法是否存在该注解)
        RolePermission annotationInMethod = AnnotationUtils.findAnnotation(signature.getMethod(), RolePermission.class);

        /*
          或者:
          MethodSignature signature = (MethodSignature) joinPoint.getSignature();
          Class<?> tagClass = signatureInMethod.getDeclaringType();
          boolean annotation = tagClass.isAnnotationPresent(HasPermission.class);
          HasPermission annotationInClass=null;
          if(annotation){
              annotationInClass = tagClass.getAnnotation(HasPermission.class);
          }
         */

        //....
        //具体业务逻辑
        //....

        return joinPoint.proceed(args);
    }
}

 2. 拦截器方式

package com.dj.springboot.study.interceptor;

import com.dj.springboot.study.annotation.RolePermission;
import lombok.extern.slf4j.Slf4j;
import org.springframework.core.annotation.AnnotationUtils;
import org.springframework.stereotype.Component;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerInterceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * @Author: ldj
 * @Date: 2024/02/20/14:45
 * @Description: 拦截器实现获取鉴权注解
 */
@Slf4j
@Component
public class PermissionInterceptor implements HandlerInterceptor {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
        HandlerMethod handlerMethod = (HandlerMethod) handler;
        //1.获取目标类上的目标注解(可判断目标类是否存在该注解)
        RolePermission annotation = AnnotationUtils.findAnnotation(handlerMethod.getBeanType(), RolePermission.class);
        //2.获取目标方法上的目标注解(可判断目标方法是否存在该注解)
        RolePermission annotationInMethod = AnnotationUtils.findAnnotation(handlerMethod.getMethod(), RolePermission.class);

        //..业务逻辑代码,如果返回false,表示鉴权失败,不放行

        return false;
    }

}

 补充:鉴权注解定义

package com.dj.springboot.study.annotation;

import com.dj.springboot.study.enums.LogicalType;
import org.springframework.core.annotation.AliasFor;

import java.lang.annotation.*;

/**
 * @Author: ldj
 * @Date: 2023/08/29/10:06
 * @Description: 角色权限注解
 */
@Documented
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface RolePermission {

    @AliasFor(value = "roles")
    String[] value() default {};

    @AliasFor(value = "value")
    String[] roles() default {};

    //逻辑条件: 与、或
    LogicalType logical() default LogicalType.AND;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值