亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

shiro與spring集成的示例分析

發布時間:2021-08-17 09:39:37 來源:億速云 閱讀:129 作者:小新 欄目:編程語言

這篇文章將為大家詳細講解有關shiro與spring集成的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

shiro的四大基石

  • 身份驗證(登錄)Authentication:身份認證 / 登錄,驗證用戶是不是擁有相應的身份;

  • 授權(權限)Authorization:驗證某個已登錄的用戶是否擁有某個權限

  • 密碼學(密碼加密) Cryptography:加密,保護數據的安全性,如密碼加密存儲到數據庫,而不是明文存儲;

  • 會話管理 Session Management:用戶登錄后就是一次會話,在沒有退出之前,它的所有信息都在會話中;

導包

<!--使用shiro需要先導包-->
<dependencies>
  <!--shiro的核心包-->
  <dependency>
    <groupId>org.apache.shiro</groupId>
    <artifactId>shiro-core</artifactId>
    <version>1.4.0</version>
  </dependency>
  <!--日志包-->
  <dependency>
    <groupId>commons-logging</groupId>
    <artifactId>commons-logging</artifactId>
    <version>1.2</version>
  </dependency>
  <!--測試包-->
  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.9</version>
  </dependency>
</dependencies>

ini文件(再創建shiro.ini文件)文件中有咱們的用戶角色權限

# ini文件里面放的就是咱們的用戶,角色,權限,資源

# -----------------------------------------------------------------------------
# users:用戶
#  root:用戶名 123456:密碼 admin:角色
# -----------------------------------------------------------------------------
[users]
root = 123456, admin
guest = guest, it

# -----------------------------------------------------------------------------
# roles:角色
#  admin = * :admin這個用戶擁有所有權限
#  it = employee:* :it這個角色擁有員工的所有權限
#  hr = employee:save :hr這個角色擁有員工添加權限
# -----------------------------------------------------------------------------
[roles]
admin = *
it = employee:*
hr = employee:save

功能測試(一定要有測試包org.junit.Test才能測試)

主要測試登錄,權限認證

@Test
public void testHello() throws Exception{
  //①.拿到權限管理對象
  /**
   * 讀取了shiro.ini的文件(隱藏了realm) -> 隱藏了iniRealm
   * SecurityManager:權限管理器,shiro的所有功能都放在里面
   */
  Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:shiro.ini");
  SecurityManager securityManager = factory.getInstance();
  //②.相當于把SecurityManager放到了當前上下文
  /**
   * 可以讓我們在當前系統的任何位置都可以拿到SecurityManager對象
   */
  SecurityUtils.setSecurityManager(securityManager);
  //③.拿到當前用戶(沒有登錄就是游客)
  Subject currentUser = SecurityUtils.getSubject();
  System.out.println("用戶是否登錄:"+currentUser.isAuthenticated());

  //④.如果沒有登錄,讓他進行登錄
  if(!currentUser.isAuthenticated()){
    //ctrl+alt+t :包含代碼
    try {
      //4.1 準備令牌(對象) 用戶名密碼令牌
      UsernamePasswordToken token = new UsernamePasswordToken("guest","guest");
      //4.2 進行登錄功能
      currentUser.login(token);
    } catch (UnknownAccountException e) {
      //Unknown(未知)Account(賬號)Exception:用戶名不存在
      e.printStackTrace();
      System.out.println("哥,你是傻子嘛?");
    }catch (IncorrectCredentialsException e){
      //Incorrect(不正確)Credentials(憑證)Exception:密碼錯誤
      e.printStackTrace();
      System.out.println("哥,密碼錯誤了?");
    }catch (AuthenticationException e){
      //AuthenticationException:登錄中最大的那個異常
      e.printStackTrace();
      System.out.println("發生了一個神秘的錯誤!!!");
    }
  }
  System.out.println("用戶是否登錄:"+currentUser.isAuthenticated());

  System.out.println("是否是管理員角色:"+currentUser.hasRole("admin"));
  System.out.println("是否是IT角色:"+currentUser.hasRole("it"));

  System.out.println("是否可以操作employee:save權限:"+currentUser.isPermitted("employee:save"));
  System.out.println("是否可以操作employee:index權限:"+currentUser.isPermitted("employee:index"));
  System.out.println("是否可以操作department:index權限:"+currentUser.isPermitted("department:index"));

  //⑤.還可以登出(注銷)
  currentUser.logout();
  System.out.println("用戶是否登錄:"+currentUser.isAuthenticated());
}

關于“shiro與spring集成的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

社旗县| 军事| 类乌齐县| 大庆市| 崇信县| 武穴市| 吉林市| 秀山| 广饶县| 前郭尔| 松溪县| 岳池县| 互助| 龙游县| 武陟县| 麟游县| 财经| 牙克石市| 胶南市| 崇左市| 贵德县| 邢台市| 襄汾县| 扎兰屯市| 武川县| 科尔| 枝江市| 漳州市| 彩票| 都江堰市| 仙居县| 韩城市| 闵行区| 永胜县| 沂南县| 洛川县| 光泽县| 册亨县| 邯郸市| 广德县| 阳东县|