shiro框架学习-3- Shiro内置realm


1. shiro默认自带的realm和常见使用方法

  • realm作用:Shiro 从 Realm 获取安全数据
  • 默认自带的realm:idae查看realm继承关系,有默认实现和自定义继承的realm
  • 两个概念
    • principal : 主体的标示,可以有多个,但是需要具有唯一性,常见的有用户名,手机号,邮箱等
    • credential:凭证, 一般就是密码
    • 所以一般我们说 principal + credential 就账号 + 密码
  • 开发中,往往是自定义realm , 即集成 AuthorizingRealm,重写AuthorizingRealm的getAuthorizationInfo方法

2.  Shiro内置 ini realm 操作

在springboot的resources资源目录下创建shiro.ini 配置文件,将下面内容复制进去

 1 [users]  2 # 格式 name=password,role1,role2,..roleN  3 jack = 456, user  4 xdclass = 123, root, admin  5 # 格式 role=permission1,permission2...permissionN 也可以用通配符  6 # 下面配置user的权限为所有video:find,video:buy,如果需要配置video全部操作crud 则 user = video:*
 7 [roles]  8 user = video:find,video:buy  9 # 下面定义了游客角色具有商品模块的查询,购买权限以及评论模块的所有权限 10 visitor= good:find,good:buy,comment:*
11 # 'admin' role has all permissions, indicated by the wildcard '*'
12 admin = *
xdclass = 123, root, admin  表示,xdclass这个用户密码是123,具有 root 和admin两个角色,
user = video:find,video:buy 表示,普通用户角色具有视频的查看,购买权限,
admin = *  表示admin角色具有所有的权限

测试代码:

 1 package net.xdclass.xdclassshiro;  2 
 3 import org.apache.shiro.SecurityUtils;  4 import org.apache.shiro.authc.UsernamePasswordToken;  5 import org.apache.shiro.config.IniSecurityManagerFactory;  6 import org.apache.shiro.mgt.DefaultSecurityManager;  7 import org.apache.shiro.mgt.SecurityManager;  8 import org.apache.shiro.realm.SimpleAccountRealm;  9 import org.apache.shiro.subject.Subject; 10 import org.apache.shiro.util.Factory; 11 import org.junit.Before; 12 import org.junit.Test; 13 
14 /**
15  * iniRealm操作 16  */
17 public class QuicksStratTest5_2 { 18 
19  @Test 20     public void testAuthentication() { 21         //通过配置文件创建SecurityManager工厂
22         Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:shiro.ini"); 23        // 获取SecurityManager实例
24         SecurityManager securityManager = factory.getInstance(); 25         //设置当前上下文
26  SecurityUtils.setSecurityManager(securityManager); 27 
28         //获取当前subject(application应用的user)
29         Subject subject = SecurityUtils.getSubject(); 30         // 模拟用户输入
31         UsernamePasswordToken usernamePasswordToken = new UsernamePasswordToken("jack","456"); 32         // 33  subject.login(usernamePasswordToken); 34         System.out.println("认证结果(是否已授权):" + subject.isAuthenticated());  //认证结果(是否已授权):true 35         //最终调用的是org.apache.shiro.authz.ModularRealmAuthorizer.hasRole方法
36         System.out.println("是否有对应的角色:" + subject.hasRole("root"));  //是否有对应的角色:false 37         //获取登录 账号
38         System.out.println("getPrincipal():" + subject.getPrincipal());  //getPrincipal():jack 39         //校验角色,没有返回值,校验不通过,直接跑出异常
40         subject.checkRole("user"); 41         // user jack有video的find权限,执行通过
42         subject.checkPermission("video:find"); 43         // 是否有video:find权限:true
44         System.out.println("是否有video:find权限:" + subject.isPermitted("video:find")); 45         // 是否有video:delete权限:false
46         System.out.println("是否有video:delete权限:" + subject.isPermitted("video:delete")); 47         //user jack没有video的删除权限,执行会报错:org.apache.shiro.authz.UnauthorizedException: Subject does not have permission [video:delete]
48         subject.checkPermission("video:delete"); 49 // subject.logout(); 50 // System.out.println("logout后认证结果:" + subject.isAuthenticated());
51  } 52 
53  @Test 54     public void testAuthentication2() { 55         //通过配置文件创建SecurityManager工厂
56         Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:shiro.ini"); 57         // 获取SecurityManager实例
58         SecurityManager securityManager = factory.getInstance(); 59         //设置当前上下文
60  SecurityUtils.setSecurityManager(securityManager); 61         //获取当前subject(application应用的user)
62         Subject subject = SecurityUtils.getSubject(); 63         // 模拟用户输入
64         UsernamePasswordToken usernamePasswordToken = new UsernamePasswordToken("xdclass","123"); 65  subject.login(usernamePasswordToken); 66         System.out.println("认证结果(是否已授权):" + subject.isAuthenticated()); // 认证结果(是否已授权):true 67         //最终调用的是org.apache.shiro.authz.ModularRealmAuthorizer.hasRole方法
68         System.out.println("是否有admin角色:" + subject.hasRole("admin")); //是否有admin角色:true
69         System.out.println("是否有root角色:" + subject.hasRole("root"));  //是否有root角色:true 70         //获取登录 账号
71         System.out.println("getPrincipal():" + subject.getPrincipal());  //getPrincipal():xdclass 72         // admin角色具有所有权限
73         subject.checkPermission("video:find"); 74         // 是否有video:find权限:true
75         System.out.println("是否有video:find权限:" + subject.isPermitted("video:find"));  //是否有video:find权限:true 76         // 是否有video:delete权限:true
77         System.out.println("是否有video:delete权限:" + subject.isPermitted("video:delete")); // 是否有video:find权限:true 78         // 结果为true,如果subject.checkPermission校验不通过,则抛出异常
79         subject.checkPermission("video:delete"); 80  } 81 }

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM