若依-数据权限管理-DataScope

本文介绍了如何在开发中通过@DataScope注解和MyBatis实现用户数据权限的设置,关注部门和用户级别的访问控制,以及如何利用Aspect进行SQL拼装以确保敏感数据的安全性。

在实际开发中,需要设置用户只能查看哪些部门的数据,这种情况一般称为数据权限。
例如对于销售,财务的数据,它们是非常敏感的,因此要求对数据权限进行控制, 对于基于集团性的应用系统而言,就更多需要控制好各自公司的数据了。如设置只能看本公司、或者本部门的数据,对于特殊的领导,可能需要跨部门的数据, 因此程序不能硬编码那个领导该访问哪些数据,需要进行后台的权限和数据权限的控制。
开发过程如下

第一步:@DataScope注解

// 部门数据权限注解
@DataScope(deptAlias = "u")
// 部门及用户权限注解
@DataScope(deptAlias = "d", userAlias = "u")

第二步:在mybatis查询底部标签添加数据范围过滤

 

 

params的入参是前端传递对象的(例如:SysUserResult),因为所有的VO对象都继承了BaseEntity,这个类里面有个属性就是
/** 请求参数 */
private Map<String, Object> params;

+前端传递params的方式

 

 注意:要想实现数据权限必须使用框架生成的对象类,或者继承BaseEntity类。

第三步:使用Aspect来实现sql的拼装,实现数据权限的过滤

 

 说明:@DataScope(deptAlias = "d", userAlias = "u")
d:表示拼接sql是表别名 sys_dept d
u:表示拼接sql是表别名 sys_user u

 

1、无需安装,启动即用; 2、支持同时刷新多达10个通道的单精度浮点型数据; 3、支持多种格式的通道数据导入、导出及回放; 4、支持全屏浏览; 5、支持图表数据统计、测量及缩放; 6、支持蓝牙适配器; 7、支持各通道独立刷新; 8、支持3D轨迹显示; 9、3D立方体显示; 10、航空仪表; 11、灵活可屏蔽的快捷键支持。 (1)数据输入: DataScope_Get_Channel_Data( rand()/100000000 , 1 ); 实现的是将数据写入通道,这里选择的是通道1,如果选择多个通道,可以写成如下形式:DataScope_Get_Channel_Data( 1.0 , 1 ); //将数据 1.0 写入通道 1 DataScope_Get_Channel_Data( 2.0 , 2 ); //将数据 2.0 写入通道 2 DataScope_Get_Channel_Data( 3.0 , 3 ); //将数据 3.0 写入通道 3 DataScope_Get_Channel_Data( 4.0 , 4 ); //将数据 4.0 写入通道 4 DataScope_Get_Channel_Data( 5.0 , 5 ); //将数据 5.0 写入通道 5 DataScope_Get_Channel_Data( 6.0 , 6 ); //将数据 6.0 写入通道 6 DataScope_Get_Channel_Data( 7.0 , 7 ); //将数据 7.0 写入通道 7 DataScope_Get_Channel_Data( 8.0 , 8 ); //将数据 8.0 写入通道 8 DataScope_Get_Channel_Data( 9.0 , 9 ); //将数据 9.0 写入通道 9 DataScope_Get_Channel_Data( 10.0 , 10); //将数据 10.0 写入通道 10 (2) 数据转换(转换为上位机可以理解的数据格式):Send_Count = DataScope_Data_Generate(1); (3) 传输数据到电脑(上位机):for( i = 0 ; i SR&0X40;)==0); USART1->DR = DataScope_OutPut_Buffer[i]; } Delay(0xFFFFFF); 里面有具体的使用说明,不会的可以及时联系我
### 若依系统的角色管理数据权限配置 #### 角色管理概述 若依系统(RuoYi-Cloud)是一个基于Spring BootSpring Cloud和Alibaba技术栈的分布式微服务架构权限管理系统。该平台提供了强大的用户角色管理和灵活的数据权限配置功能,能够满足不同业务场景下的安全管理需求[^3]。 #### 创建与编辑角色 在若依系统中创建新角色或修改现有角色时,可以通过后台管理界面完成操作。具体来说: 1. 登录到若依系统的管理控制台; 2. 导航至“系统工具”> “角色管理”,点击进入角色列表页面; 3. 对于新建角色,在页面上方找到并单击【新增】按钮;对于已有角色,则先选中目标记录再点击右侧的操作栏中的【编辑】链接; 4. 输入必要的基本信息如名称、描述等字段内容,并设定相应的菜单访问权限以及特定资源级别的细粒度授权策略; 5. 完成设置后保存更改即可生效。 ```json { "roleName": "财务专员", "roleKey": "finance_specialist", "dataScope": "自定义", "menuIds": [ 100, 101, ... ], "deptIdList": [] } ``` 上述JSON片段展示了如何通过API接口提交一个新的角色对象实例给服务器端处理程序来实现自动化脚本部署流程的一部分。 #### 数据权限配置详解 为了更好地保护敏感信息并且提高工作效率,若依允许为不同的部门或者岗位定制化其可查看的数据范围。这通常涉及到以下几个方面的工作: - **全局参数调整**:可以在应用启动前通过环境变量或其他方式指定一些通用性的过滤条件应用于整个应用程序上下文中。 - **动态SQL查询增强**:利用MyBatis框架提供的插件机制编写专门针对某些表结构设计好的拦截器组件,从而实现在运行期间自动附加额外WHERE子句的效果而不必改动原始Mapper文件内的任何语句逻辑。 - **前端展示层优化**:当渲染表格视图之前预先计算好哪些列应该被隐藏起来不让当前登录者看见,以此达到最小化暴露原则的要求。 ```sql SELECT * FROM sys_user WHERE dept_id IN ( SELECT d.dept_id FROM sys_dept d JOIN sys_role_dept rd ON d.dept_id = rd.dept_id JOIN sys_role r ON rd.role_id = r.role_id JOIN sys_user_role ur ON r.role_id = ur.role_id WHERE ur.user_id = #{userId} AND r.data_scope = '自定义' ); ``` 这段SQL代码说明了怎样依据用户的所属职位去检索他们所能接触到的具体员工资料集合。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值