一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - springboot整合shiro之thymeleaf使用shiro標簽的方法

springboot整合shiro之thymeleaf使用shiro標簽的方法

2022-02-28 13:11桐花思雨 Java教程

Thymeleaf 是一個跟 Velocity、FreeMarker 類似的模板引擎,它可以完全替代 JSP ,這篇文章主要介紹了springboot整合shiro之thymeleaf使用shiro標簽的相關知識,需要的朋友可以參考下

thymeleaf介紹

簡單說, Thymeleaf 是一個跟 Velocity、FreeMarker 類似的模板引擎,它可以完全替代 JSP 。相較與其他的模板引擎,它有如下三個極吸引人的特點:

1.Thymeleaf 在有網絡和無網絡的環境下皆可運行,即它可以讓美工在瀏覽器查看頁面的靜態效果,也可以讓程序員在服務器查看帶數據的動態頁面效果。這是由于它支持 html 原型,然后在 html 標簽里增加額外的屬性來達到模板+數據的展示方式。瀏覽器解釋 html 時會忽略未定義的標簽屬性,所以 thymeleaf 的模板可以靜態地運行;當有數據返回到頁面時,Thymeleaf 標簽會動態地替換掉靜態內容,使頁面動態顯示。

2.Thymeleaf 開箱即用的特性。它提供標準和spring標準兩種方言,可以直接套用模板實現JSTL、 OGNL表達式效果,避免每天套模板、該jstl、改標簽的困擾。同時開發人員也可以擴展和創建自定義的方言。

3.Thymeleaf 提供spring標準方言和一個與 SpringMVC 完美集成的可選模塊,可以快速的實現表單綁定、屬性編輯器、國際化等功能。

我們緊接著 上一篇 文章,我們使用賬號 jack 和賬號 Tom 來分別登錄,在上一篇文章測試中可以看到,這兩個賬號無論哪一個登錄,首頁頁面都會顯示 add 頁面和 update 頁面兩個超鏈接,而對于這兩個賬號來說,一個擁有訪問 add 頁面的權限,一個擁有訪問 update 頁面的權限。那么問題來了,如何才能根據不同用戶的身份角色信息來顯示不同的頁面內容呢?這就要使用 shiro 標簽了

thymeleaf 模板引擎使用 shiro 標簽

引入依賴

<dependency>
  <groupId>com.github.theborakompanioni</groupId>
  <artifactId>thymeleaf-extras-shiro</artifactId>
  <version>2.0.0</version>
</dependency>

配置類 ShiroConfig

@Configuration
public class ShiroConfig {

  // 安全管理器
  @Bean
  public DefaultWebSecurityManager getDefaultWebSecurityManager(UserRealm userRealm) {
      DefaultWebSecurityManager defaultWebSecurityManager = new DefaultWebSecurityManager();
      defaultWebSecurityManager.setRealm(userRealm);
      return defaultWebSecurityManager;
  }

  // thymeleaf模板引擎中使用shiro標簽時,要用到
  @Bean
  public ShiroDialect getShiroDialect() {
      return new ShiroDialect();
  }

  @Bean
  public ShiroFilterFactoryBean shiroFilter(DefaultWebSecurityManager defaultWebSecurityManager) {
      ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
      shiroFilterFactoryBean.setSecurityManager(defaultWebSecurityManager);
      // 設置登錄頁面url
      shiroFilterFactoryBean.setLoginUrl("/user/login");
      shiroFilterFactoryBean.setSuccessUrl("/user/index");
      shiroFilterFactoryBean.setUnauthorizedUrl("/user/unauthorized");

      // 注意此處使用的是LinkedHashMap是有順序的,shiro會按從上到下的順序匹配驗證,匹配了就不再繼續驗證
      Map<String, String> filterChainDefinitionMap = new LinkedHashMap<>();

      filterChainDefinitionMap.put("/layer/**", "anon");// 靜態資源放行
      filterChainDefinitionMap.put("/img/**", "anon");
      filterChainDefinitionMap.put("/jquery/**", "anon");
      // add.html頁面放行
      filterChainDefinitionMap.put("/user/add", "authc");
      // update.html必須認證
      filterChainDefinitionMap.put("/user/update", "authc");
      // index.html必須通過認證或者通過記住我登錄的,才可以訪問
      filterChainDefinitionMap.put("/user/index", "user");
      // 設置授權,只有user:add權限的才能請求/user/add這個url
      filterChainDefinitionMap.put("/user/add", "perms[user:add]");
      filterChainDefinitionMap.put("/user/update", "perms[user:update]");

      shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap);
      return shiroFilterFactoryBean;
  }
}

index.html 頁面

  • 首先要引入shiro 的命名空間:xmlns:shiro=http://www.pollix.at/thymeleaf/shiro
  • 使用相應的 shiro 標簽
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org" xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
  <meta charset="UTF-8">
  <title>首頁</title>
  <link rel="shortcut icon" type="image/x-icon" th:href="@{/img/favicon.ico}" rel="external nofollow" />
</head>
<body>
  <h1>首頁</h1>

  <a shiro:hasPermission="'user:add'" th:href="@{/user/add}" rel="external nofollow" >add</a><br>
  <a shiro:hasPermission="'user:update'" th:href="@{/user/}" rel="external nofollow" >update</a>
  update
  <a th:href="@{/user/logout}" rel="external nofollow" >退出登錄</a>
</body>
</html>

shiro 標簽說明

https://shiro.apache.org/jsp-tag-library.html

https://github.com/apache/shiro/blob/main/web/src/main/resources/META-INF/shiro.tld

標簽 含義
shiro:principal 當前用戶的登錄信息,用戶名之類
shiro:guest="" 驗證是否是游客,即未認證的用戶
shiro:user="" 驗證是否是已認證或已記住用戶
shiro:authenticated="" 驗證是否是已認證用戶,不包括已記住用戶
shiro:notAuthenticated= “” 未認證用戶,但是 已記住用戶
shiro:lacksRole=“admin” 表示沒有 admin 角色的用戶
shiro:hasAllRoles=“admin, user1” 表示需要同時擁有兩種角色
shiro:hasAnyRoles=“admin, user1” 表示 擁有其中一個角色即可
shiro:lacksPermission=“admin:delete” 類似于 shiro:lacksRole
shiro:hasAllPermissions=“admin:delete, admin:edit” 類似于 shiro:hasAllRoles
shiro:hasAnyPermission=“admin:delete, admin:edit” 類似于 hasAnyRoles

 

測試

測試一

首先使用賬號 jack 來登錄,查看首頁頁面,如下

springboot整合shiro之thymeleaf使用shiro標簽的方法

再看控制臺日志,如下,注意賬號 jack 擁有的權限,在 index.html 頁面有兩個 <shiro:hasPermission> 標簽,故而進行了兩次授權操作

springboot整合shiro之thymeleaf使用shiro標簽的方法

測試二

再使用賬號 Tom 來登錄,查看首頁頁面,如下

springboot整合shiro之thymeleaf使用shiro標簽的方法

再看控制臺日志,如下,注意賬號 Tom 擁有的權限,在 index.html 頁面有兩個 <shiro:hasPermission> 標簽,故而進行了兩次授權操作

springboot整合shiro之thymeleaf使用shiro標簽的方法

源碼:springboot-shiro

到此這篇關于springboot整合shiro之thymeleaf使用shiro標簽的文章就介紹到這了,更多相關springboot整合shiro使用shiro標簽內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/weixin_38192427/article/details/120922490

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 午夜国产精品福利在线观看 | 成年美女黄网站色视频大全免费 | 国产66| 亚洲欧美国产精品完整版 | 教室里老师好紧h | 国产精品二区高清在线 | 婷婷影院在线观看 | 黄动漫车车好快的车车双女主 | 日本一道高清不卡免费 | 美女一级ba大片免色 | 韩国最新理论片奇忧影院 | 久久re亚洲在线视频 | 青柠网在线观看视频 | 娇妻被又大又粗又长又硬好爽 | 成人黄页网站 | 91精品天美精东蜜桃传媒免费 | 日本国产成人精品视频 | 唯美 清纯 另类 亚洲制服 | 非洲黑人又大粗gay 非洲黑人bbwbbwbbw | 日韩精品一区二区 | 小货SAO边洗澡边CAO你动漫 | 欧美一级久久久久久久大片 | 精品久久久久久午夜 | 妇乱子伦激情 | tube日本高清老少配 | 粉嫩极品国产在线观看免费 | 亚洲高清色图 | 秋霞黄色网 | 好男人天堂网 | 国产永久一区二区三区 | 美女在尿口隐私视频 | 国产乱子伦真实china | 国产成人精品高清在线观看99 | 免费看国产一级片 | 亚洲第一综合网 | 亚洲色图网址 | 国产精品99在线观看 | 欧美区在线 | 亚欧美综合 | 亚洲AV久久久久久久无码 | 天天做天天爽天天谢 |