A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

本帖最后由 谷粒姐姐 于 2018-4-10 10:05 编辑

4 用户授权功能实现  
用户授权功能主要解决 用户能操作哪些功能问题  !
4.1 对页面部分功能添加权限和角色需要  

修改 applicationContext-shiro.xml 配置 shiroFilter  权限过滤程序  
访问 courier.html 时,因为需要特别权限 调用 自定义 Realm 的 doGetAuthorizationInfo
进行授权,如果没有权限,跳转  
         <property name="unauthorizedUrl" value="/unauthorized.html" />  
4.2 在数据表中导入预定义角色、权限数据  
导入 t_user_role_permission.sql   
权限数据  
角色数据  
角色 权限 关系表  
用户表  
用户 角色关系表  
4.3.实现 Realm 的授权方法
Realm
创建角色 Service、DAO
创建权限 Service、DAO  


5 Apache Shiro 实现方法级别细粒度权限控制  
细粒度(方法)权限控制原因: 自定义注解(加在方法上,在注解中描述需要权限信息),对目标业务对象创建代理对象,在代理方法中使用反射技术读取注解信息,获取需要权限,查询当前登录用户具有权限是否满足  
1、 配置 applicationContext-shiro.xml  激活注解  
传统 spring AOP 配置 , 对 spring bean 创建代理 Advisor ,会在业务 Bean 使用 shiro 注解, 配置自动代理模式 (对所有 spring 管理 bean 的方法,执行时,检查是否有 shiro 注解 )
2、 配置快递员添加 方法,业务层使用 shiro 注解  


注意问题:
针对 CourierServiceImpl 对象进行代理 !!!  解决:  
applicationContext-dataSource.xml  
applicationContext-shiro.xml  
使用方法注解进行权限控制, 当权限不足时,代理对象抛出一个异常  
org.apache.shiro.authz.UnauthorizedException: Subject does not have permission [courier_add]

bos项目笔记之chapter08_系统分析、环境搭建(5)

1 个回复

倒序浏览
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马