shiro認證單元測試

初學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
    }
}

最後測試成功,達到預期的效果

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章