《权限系列》----用SpringAop控制权限二

2024-08-27 20:38
文章标签 系列 控制 权限 springaop

本文主要是介绍《权限系列》----用SpringAop控制权限二,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

  • 接着上一篇博客说,上一篇文章已经将大部分代码贴出来了,下面该轮到核心代码了,Spring Aop的切面代码。

项目源码

点击这里,到github上下载项目的源码

切面代码

public class PermissionAspect {@Resource
private CheckAuthorityService checkAuthorityService;public void doBefore(JoinPoint jp) throws IOException{Method soruceMethod = getSourceMethod(jp);if(soruceMethod!=null){ValidatePermission oper = soruceMethod.getAnnotation(ValidatePermission.class);if (oper != null) {String flag= oper.authority();Object[] args = jp.getArgs();HttpServletRequest request =((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();HttpSession session =request.getSession(); boolean status = checkAuthorityService.checkAccess(flag,session);if(status){return ;//正常}else{throw new AccessDeniedException("无权操作该功能!");}}}
}private Method getSourceMethod(JoinPoint jp){Method proxyMethod = ((MethodSignature) jp.getSignature()).getMethod();try {return jp.getTarget().getClass().getMethod(proxyMethod.getName(), proxyMethod.getParameterTypes());} catch (NoSuchMethodException e) {e.printStackTrace();} catch (SecurityException e) {e.printStackTrace();}return null;}
}
  • 在切面中,我们利用反射,将请求方法上的注解拿到,然后读取此注解中的权限信息,最后将注解信息和session作为参数一块传入到checkAccess()方法中检查权限,下面是要访问的Controller中的方法。

要访问的目标方法

@ValidatePermission(authority="create")
@RequestMapping("/create")
@ResponseBody
public List<String> createUser(){userService.addUser(null);List<String> list=Arrays.asList("新增用户信息成功");return list;
}

检查权限

public class CheckAuthorityServiceImpl implements CheckAuthorityService {@Resourceprivate PermissionMapper permissionMapper;@Resourceprivate JedisClient jedisClient;public Map<String, String> authorityMap = null;@Overridepublic boolean checkAccess(String flag, HttpSession session) {String desUrl="";boolean desFlag=false;//在session中获取登录名String loginName = (String) session.getAttribute("userLoginName");//在session中获取用户角色IDInteger roleID= (Integer) session.getAttribute("roleID");String ROLE_ID_MAP="ROLEID_PERMISSION:"+roleID.toString()+"_"+"MAP";//在redis中查找存放资源的map,若map存在,则通过目标资源获取authorityMap=jedisClient.hgetAll(ROLE_ID_MAP);if (authorityMap!=null && authorityMap.size()>0){//匹配资源 这是的时间复杂度大约为O(1)desUrl=authorityMap.get(flag);}else {//若存放资源的map不存在,在数据库中将资源搜出来,放入map中,这时候map的key就是资源(Url)value 是1 目的是省内存List<String> list = permissionMapper.getPermissions(loginName);if (list != null && list.size() > 0) {for (String str : list) {authorityMap.put(str,"1");}//匹配资源 这是的时间复杂度大约为O(1)desUrl=authorityMap.get(flag);//将map放入redis中jedisClient.hmset(ROLE_ID_MAP,authorityMap);}}//判断资源是否匹配成功if (StringUtils.isNoneBlank(desUrl)){desFlag=true;}return desFlag;}
}
  • 在小编做的项目中,用户是可以不断增加角色的,也就是说角色是变化的,因为不同的角色对应着不同的资源,所以在检查用户权限的时候,小编将资源信息存入一个HashMap中,然后叫此HashMap放入Redis中,当每次判断权限时,我们根据用户的角色ID将map从redis中取出来,然后根据目标资源去map中get(),这样以来,get()的时间复杂度是O(1),提高效率。

小结

  • 置于redis的使用,请见第三篇博客。

这篇关于《权限系列》----用SpringAop控制权限二的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112720

相关文章

Java访问修饰符public、private、protected及默认访问权限详解

《Java访问修饰符public、private、protected及默认访问权限详解》:本文主要介绍Java访问修饰符public、private、protected及默认访问权限的相关资料,每... 目录前言1. public 访问修饰符特点:示例:适用场景:2. private 访问修饰符特点:示例:

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

Mybatis拦截器如何实现数据权限过滤

《Mybatis拦截器如何实现数据权限过滤》本文介绍了MyBatis拦截器的使用,通过实现Interceptor接口对SQL进行处理,实现数据权限过滤功能,通过在本地线程变量中存储数据权限相关信息,并... 目录背景基础知识MyBATis 拦截器介绍代码实战总结背景现在的项目负责人去年年底离职,导致前期规

Python实现局域网远程控制电脑

《Python实现局域网远程控制电脑》这篇文章主要为大家详细介绍了如何利用Python编写一个工具,可以实现远程控制局域网电脑关机,重启,注销等功能,感兴趣的小伙伴可以参考一下... 目录1.简介2. 运行效果3. 1.0版本相关源码服务端server.py客户端client.py4. 2.0版本相关源码1

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

GPT系列之:GPT-1,GPT-2,GPT-3详细解读

一、GPT1 论文:Improving Language Understanding by Generative Pre-Training 链接:https://cdn.openai.com/research-covers/languageunsupervised/language_understanding_paper.pdf 启发点:生成loss和微调loss同时作用,让下游任务来适应预训