原博客地址:http://jinnianshilongnian.iteye.com/blog/2018398
根据下载的pdf学习。
第六章 Realm及相关对象(三)
1.准备3个Realm
MyRealm1,MyRealm2,MyRealm3。
(1)MyRealm1
public class MyRealm1 implements Realm { @Override
public String getName() {
return "a"; //realm name 为 “a”
} @Override
public boolean supports(AuthenticationToken token) {
return token instanceof UsernamePasswordToken;
} @Override
public AuthenticationInfo getAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
return new SimpleAuthenticationInfo(
"zhang", //身份 字符串类型
"123", //凭据
getName() //Realm Name
);
}
}
(2)MyRealm2
和Realm1的代码一样,只是getName返回的是“b”。
(3)MyRealm3
MyRealm3的名字是c,并且返回的信息中,参看代码第17行,是User类型的身份
public class MyRealm3 implements Realm { @Override
public String getName() {
return "c"; //realm name 为 “c”
} @Override
public boolean supports(AuthenticationToken token) {
return token instanceof UsernamePasswordToken;
} @Override
public AuthenticationInfo getAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
User user = new User("zhang", "123");
return new SimpleAuthenticationInfo(
user, //身份 User类型
"123", //凭据
getName() //Realm Name
);
}
}
2.ini配置
3.测试用例
public class PrincialCollectionTest extends BaseTest { @Test
public void test() { //每个Realm都身份验证成功了
login("classpath:shiro-multirealm.ini", "zhang", "123");
Subject subject = subject();
//获取Primary Principal(即第一个)
Object primaryPrincipal1 = subject.getPrincipal();
PrincipalCollection princialCollection = subject.getPrincipals();
Object primaryPrincipal2 = princialCollection.getPrimaryPrincipal(); //但是因为多个Realm都返回了Principal,所以此处到底是哪个是不确定的
Assert.assertEquals(primaryPrincipal1, primaryPrincipal2); //返回 a b c
Set<String> realmNames = princialCollection.getRealmNames();
System.out.println(realmNames); //因为MyRealm1和MyRealm2返回的凭据都是zhang,所以排重了
Set<Object> principals = princialCollection.asSet(); //asList和asSet的结果一样
System.out.println(principals); //根据Realm名字获取,由于多个Realm可以重名,所以使用时可能返回多个身份。防止这种情况,就是尽量不要重名。
Collection<User> users = princialCollection.fromRealm("c");
System.out.println(users);
}
}