SpringBoot使用AOP+注解實(shí)現(xiàn)簡(jiǎn)單的權(quán)限驗(yàn)證的方法
SpringAOP的介紹:傳送門(mén)
demo介紹
主要通過(guò)自定義注解,使用SpringAOP的環(huán)繞通知攔截請(qǐng)求,判斷該方法是否有自定義注解,然后判斷該用戶是否有該權(quán)限。這里做的比較簡(jiǎn)單,只有兩個(gè)權(quán)限:一個(gè)普通用戶、一個(gè)管理員。
項(xiàng)目搭建
這里是基于SpringBoot的,對(duì)于SpringBoot項(xiàng)目的搭建就不說(shuō)了。在項(xiàng)目中添加AOP的依賴:<!--more--->
<!--AOP包--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency>
自定義注解及解析
在方法上添加該注解,說(shuō)明該方法需要管理員權(quán)限才能訪問(wèn)。
@Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) @Documented public @interface Permission { String authorities() default "ADMIN"; }
解析類(lèi):通過(guò)AOP的環(huán)繞通知獲取方法上的注解,判斷是否有Permission注解,返回注解的值。
public class AnnotationParse { /*** * 解析權(quán)限注解 * @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環(huán)繞通知
@Aspect @Component public class ControllerAspect { private final static Logger logger = LoggerFactory.getLogger(ControllerAspect.class); @Autowired private UserService userService; /** * 定義切點(diǎn) */ @Pointcut("execution(public * com.wqh.blog.controller.*.*(..))") public void privilege(){} /** * 權(quán)限環(huán)繞通知 * @param joinPoint * @throws Throwable */ @ResponseBody @Around("privilege()") public Object isAccessMethod(ProceedingJoinPoint joinPoint) throws Throwable { //獲取訪問(wèn)目標(biāo)方法 MethodSignature methodSignature = (MethodSignature)joinPoint.getSignature(); Method targetMethod = methodSignature.getMethod(); //得到方法的訪問(wèn)權(quán)限 final String methodAccess = AnnotationParse.privilegeParse(targetMethod); //如果該方法上沒(méi)有權(quán)限注解,直接調(diào)用目標(biāo)方法 if(StringUtils.isBlank(methodAccess)){ return joinPoint.proceed(); }else { //獲取當(dāng)前用戶的權(quán)限,這里是自定義的發(fā)那個(gè)發(fā) User currentUser = userService.getCurrentUser(); logger.info("訪問(wèn)用戶,{}",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); } } } }
使用
只需要在需要驗(yàn)證的方法上添加自定義注解: @Permission既可
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- springboot使用自定義注解實(shí)現(xiàn)aop切面日志
- SpringBoot使用AOP記錄接口操作日志詳解
- SpringBoot使用AOP實(shí)現(xiàn)統(tǒng)計(jì)全局接口訪問(wèn)次數(shù)詳解
- 在springboot中使用AOP進(jìn)行全局日志記錄
- SpringBoot使用AOP,內(nèi)部方法失效的解決方案
- Springboot使用@Valid 和AOP做參數(shù)校驗(yàn)及日志輸出問(wèn)題
- 詳解基于SpringBoot使用AOP技術(shù)實(shí)現(xiàn)操作日志管理
- SpringBoot中使用AOP打印接口日志的方法
- SpringBoot項(xiàng)目中使用AOP的方法
- Springboot 中使用 Aop代碼實(shí)戰(zhàn)教程
相關(guān)文章
淺析Java中StringBuffer和StringBuilder的使用
當(dāng)對(duì)字符串進(jìn)行修改的時(shí)候,需要使用 StringBuffer 和 StringBuilder 類(lèi)。本文就來(lái)和大家簡(jiǎn)單聊聊這二者的使用與區(qū)別吧,希望對(duì)大家有所幫助2023-04-04MyBatis圖文并茂講解注解開(kāi)發(fā)多對(duì)多查詢
這篇文章主要介紹了SpringBoot中Mybatis注解多對(duì)多查詢的實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07Springboot項(xiàng)目啟動(dòng)找不到啟動(dòng)類(lèi)的解決
這篇文章主要介紹了Springboot項(xiàng)目啟動(dòng)找不到啟動(dòng)類(lèi)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08細(xì)談java同步之JMM(Java Memory Model)
Java內(nèi)存模型是在硬件內(nèi)存模型上的更高層的抽象,它屏蔽了各種硬件和操作系統(tǒng)訪問(wèn)的差異性,保證了Java程序在各種平臺(tái)下對(duì)內(nèi)存的訪問(wèn)都能達(dá)到一致的效果。下面我們來(lái)一起學(xué)習(xí)下JMM2019-05-05Java Socket編程(三) 服務(wù)器Sockets
Java Socket編程(三) 服務(wù)器Sockets...2006-12-12