亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringBoot使用AOP+注解實現簡單的權限驗證的方法

發布時間:2020-10-01 08:57:07 來源:腳本之家 閱讀:160 作者:wqh8522 欄目:編程語言

SpringAOP的介紹:傳送門

demo介紹

主要通過自定義注解,使用SpringAOP的環繞通知攔截請求,判斷該方法是否有自定義注解,然后判斷該用戶是否有該權限。這里做的比較簡單,只有兩個權限:一個普通用戶、一個管理員。

項目搭建

這里是基于SpringBoot的,對于SpringBoot項目的搭建就不說了。在項目中添加AOP的依賴:<!--more--->

<!--AOP包-->
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-aop</artifactId>
</dependency>

自定義注解及解析

在方法上添加該注解,說明該方法需要管理員權限才能訪問。

@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Permission {

   String authorities() default "ADMIN";

}

解析類:通過AOP的環繞通知獲取方法上的注解,判斷是否有Permission注解,返回注解的值。

public class AnnotationParse {
  /***
   * 解析權限注解
   * @return 返回注解的authorities值
   * @throws Exception
   */
  public static String privilegeParse(Method method) throws Exception {
    //獲取該方法
    if(method.isAnnotationPresent(Permission.class)){
      Permission annotation = method.getAnnotation(Permission.class);
      return annotation.authorities();
    }
    return null;
  }
}

SpringAOP環繞通知

@Aspect
@Component
public class ControllerAspect {

  private final static Logger logger = LoggerFactory.getLogger(ControllerAspect.class);

  @Autowired
  private UserService userService;
  /**
   * 定義切點
   */
  @Pointcut("execution(public * com.wqh.blog.controller.*.*(..))")
  public void privilege(){}

  /**
   * 權限環繞通知
   * @param joinPoint
   * @throws Throwable
   */
  @ResponseBody
  @Around("privilege()")
  public Object isAccessMethod(ProceedingJoinPoint joinPoint) throws Throwable {
    //獲取訪問目標方法
    MethodSignature methodSignature = (MethodSignature)joinPoint.getSignature();
    Method targetMethod = methodSignature.getMethod();
    //得到方法的訪問權限
    final String methodAccess = AnnotationParse.privilegeParse(targetMethod);

    //如果該方法上沒有權限注解,直接調用目標方法
    if(StringUtils.isBlank(methodAccess)){
      return joinPoint.proceed();
    }else {
      //獲取當前用戶的權限,這里是自定義的發那個發
      User currentUser = userService.getCurrentUser();
      logger.info("訪問用戶,{}",currentUser.toString());
      if(currentUser == null){
        throw new LoginException(ResultEnum.LOGIN_ERROR);
      }
      if(methodAccess.equals(currentUser.getRole().toString())){
        return joinPoint.proceed();
      }else {
        throw new BusinessException(ResultEnum.ROLE_ERROR);
      }
    }
  }
}

使用

只需要在需要驗證的方法上添加自定義注解: @Permission既可

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

浦北县| 临沧市| 太和县| 石棉县| 陆川县| 荆门市| 无棣县| 太康县| 乌拉特后旗| 遂昌县| 千阳县| 信丰县| 华亭县| 尤溪县| 嘉峪关市| 永胜县| 吉林省| 渑池县| 日喀则市| 湘阴县| 广西| 杨浦区| 阜南县| 个旧市| 大关县| 澄城县| 望谟县| 崇州市| 梅州市| 临泉县| 双江| 五家渠市| 正定县| 宕昌县| 金沙县| 滨州市| 尚义县| 商洛市| 通化市| 宜君县| 锡林浩特市|