初學shiro,對shiro的一些認知,測試完整代碼(基於junit)如下:
import org.apache.shiro.SecurityUtils;
import org.apache.shiro.authc.UsernamePasswordToken;
import org.apache.shiro.mgt.DefaultSecurityManager;
import org.apache.shiro.realm.SimpleAccountRealm;
import org.apache.shiro.subject.Subject;
import org.junit.Before;
import org.junit.Test;
public class shiroTest {
//創建relam(simplerelam)
SimpleAccountRealm sar=new SimpleAccountRealm();
@Before
public void addUser(){
//模擬數據庫的數據
sar.addAccount("Salong","123456");
}
@Test
public void test(){
//構建secuityManage環境,創建對象
DefaultSecurityManager dsm= new DefaultSecurityManager();
//將relam加入到securityManage環境中
dsm.setRealm(sar);
//主體提交認證請求
SecurityUtils.setSecurityManager(dsm);
Subject sub=SecurityUtils.getSubject();
//獲取賬號和密碼(模擬客戶端提供的數據)
UsernamePasswordToken token=new UsernamePasswordToken("Salong","123456");
//認證
sub.login(token);
System.out.println("是否認證:"+sub.isAuthenticated());//true
//退出認證
sub.logout();
System.out.println("是否認證:"+sub.isAuthenticated());//false
}
}
最後測試成功,達到預期的效果