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

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产性做久久久久久 | 国产精品永久免费视频观看 | 娇妻被老外疯狂调教 | 色综合视频在线观看 | 亚州性夜夜射在线观看 | 草草视频免费观看 | 成人久久18网站 | ai换脸明星专区在线观看 | 国产精品区一区二区免费 | www.91在线播放 | 色播开心网 | 日本免费v片一二三区 | 色小孩导航 | 隔壁老王国产在线精品 | 惩罚狠h调教灌满 | 大陆性出航 | 久久国产影院 | 波多野结衣在线中文字幕 | 久久视频这只精品99re6 | 欧美胖逼| 欧美一卡2卡三卡4卡5卡免费观看 | 成人一级黄色大片 | 免费视频精品一区二区三区 | 欧美a级完整在线观看 | 亚洲AV永久无码精品澳门 | 日本动漫黄网站在线观看 | porno美国xxxx| 教室里老师好紧h | 99 久久99久久精品免观看 | 亚洲毛片网 | 7个黑人玩北条麻妃 | 国产精品污双胞胎在线观看 | 午夜毛片在线观看 | 精品四虎国产在免费观看 | 午夜dj免费视频观看社区 | 国产ab| www.男人天堂| 亚洲国产精品久久网午夜 | 欧美日韩在线观看区一二 | 欧美一区二区三区四区在线观看 | 5555kkkk香蕉在线观看 |