| 1、首先调用Subject.isPermitted/hasRole接口,其会委托给SecurityManager |
| 2、SecurityManager接着会委托给内部组件Authorizer |
| 3、Authorizer再将其请求委托给我们的Realm去做;Realm才是真正干活的 |
| 4、Realm将用户请求的参数封装成权限对象。再从我们重写的doGetAuthorizationInfo方法中获取从数据库中查询到的权限集合 |
| 5、Realm将用户传入的权限对象,与从数据库中查出来的权限对象,进行一一对比。如果用户传入的权限对象在从数据库中查出来的权限对象中,则返回true,否则返回false |
| |
| 进行授权操作的前提:用户必须通过认证 |
| public interface SecurityService { |
| |
| |
| |
| |
| |
| |
| Map<String,String> findPasswordByLoginName(String loginName); |
| |
| |
| |
| |
| |
| |
| List<String> findRoleByLoginName(String loginName); |
| |
| |
| |
| |
| |
| |
| List<String> findPermissionByLoginName(String loginName); |
| } |
| public class SecurityServiceImpl implements SecurityService { |
| |
| @Override |
| public Map<String,String> findPasswordByLoginName(String loginName) { |
| return DigestsUtil.entryptPassword("123"); |
| } |
| |
| @Override |
| public List<String> findRoleByLoginName(String loginName) { |
| List<String> list = new ArrayList<>(); |
| list.add("admin"); |
| list.add("dev"); |
| return list; |
| } |
| |
| @Override |
| public List<String> findPermissionByLoginName(String loginName) { |
| List<String> list = new ArrayList<>(); |
| list.add("order:add"); |
| list.add("order:list"); |
| list.add("order:del"); |
| return list; |
| } |
| } |
| public class DefinitionRealm extends AuthorizingRealm { |
| |
| public DefinitionRealm() { |
| |
| HashedCredentialsMatcher hashedCredentialsMatcher = new HashedCredentialsMatcher(DigestsUtil.SHA1); |
| |
| hashedCredentialsMatcher.setHashIterations(DigestsUtil.ITERATIONS); |
| |
| setCredentialsMatcher(hashedCredentialsMatcher); |
| } |
| |
| |
| |
| |
| @Override |
| protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException { |
| |
| String loginName = (String) authenticationToken.getPrincipal(); |
| SecurityService securityService = new SecurityServiceImpl(); |
| Map<String, String> map = securityService.findPasswordByLoginName(loginName); |
| if(map.isEmpty()){ |
| throw new UnknownAccountException("账户不存在"); |
| } |
| String salt = map.get("salt"); |
| String password = map.get("password"); |
| return new SimpleAuthenticationInfo(loginName,password, ByteSource.Util.bytes(salt),getName()); |
| } |
| |
| |
| |
| |
| @Override |
| protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) { |
| |
| String loginName = (String) principalCollection.getPrimaryPrincipal(); |
| |
| SecurityService securityService = new SecurityServiceImpl(); |
| List<String> roles = securityService.findRoleByLoginName(loginName); |
| List<String> permissions = securityService.findPermissionByLoginName(loginName); |
| |
| SimpleAuthorizationInfo simpleAuthorizationInfo = new SimpleAuthorizationInfo(); |
| simpleAuthorizationInfo.addRoles(roles); |
| simpleAuthorizationInfo.addStringPermissions(permissions); |
| return simpleAuthorizationInfo; |
| } |
| |
| } |
| public class HelloShiro { |
| |
| @Test |
| public void testPermissionRealm(){ |
| Subject subject = shiroLogin(); |
| |
| System.out.println("登录结果:"+subject.isAuthenticated()); |
| |
| System.out.println("是否有管理员角色"+subject.hasRole("admin")); |
| |
| try { |
| subject.checkRole("coder"); |
| System.out.println("当前用户有coder角色"); |
| }catch (Exception ex){ |
| System.out.println("当前用户没有coder角色"); |
| } |
| |
| System.out.println("是否有查看订单的权限"+subject.isPermitted("order:list")); |
| |
| try { |
| subject.checkPermission("order:update"); |
| System.out.println("当前用户有修改的权限"); |
| }catch (Exception ex){ |
| System.out.println("当前用户没有修改的权限"); |
| } |
| } |
| |
| public Subject shiroLogin(){ |
| |
| Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:shiro.ini"); |
| |
| SecurityManager securityManager = factory.getInstance(); |
| |
| SecurityUtils.setSecurityManager(securityManager); |
| |
| Subject subject = SecurityUtils.getSubject(); |
| |
| UsernamePasswordToken usernamePasswordToken = new UsernamePasswordToken("jay","123"); |
| |
| subject.login(usernamePasswordToken); |
| return subject; |
| } |
| |
| } |
| 登录结果:true |
| 是否有管理员角色true |
| 当前用户没有coder角色 |
| 是否有查看订单的权限true |
| 当前用户没有修改的权限 |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?