細說shiro之三:在獨立應用中使用shiro

官網:https://shiro.apache.org/

?

1. 下載
在非Web環境的獨立應用中使用Shiro時,只需要shiro-core組件。
在Maven項目中的依賴配置如下:

<dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-core</artifactId><version>1.3.2</version>
</dependency>

<!-- Shiro uses SLF4J for logging. We'll use the 'simple' binding in this example app. See http://www.slf4j.org for more info. --> <dependency><groupId>org.slf4j</groupId><artifactId>slf4j-simple</artifactId><version>1.6.1</version> </dependency>

特別地!Shiro使用了日志框架slf4j,因此需要對應配置指定的日志實現組件,如:log4j,logback等。
在此,使用slf4j的簡單日志實現slf4j-simple。


2. 數據源配置
在Shiro中,Realm定義了訪問數據的方式,用來連接不同的數據源,如:LDAP,關系數據庫,配置文件等等。
Realm類圖:

也就是說,可以根據實際需求及應用的權限管理復雜度靈活選擇指定數據源。
在此,以org.apache.shiro.realm.text.IniRealm為例,具體配置如下:

shiro.ini:

# =============================================================================
# Tutorial INI configuration
#
# Usernames/passwords are based on the classic Mel Brooks' film "Spaceballs" :)
# =============================================================================# -----------------------------------------------------------------------------
# Users and their (optional) assigned roles
# username = password, role1, role2, ..., roleN
# -----------------------------------------------------------------------------
[users]
root = secret, admin
guest = guest, guest
presidentskroob = 12345, president
darkhelmet = ludicrousspeed, darklord, schwartz
lonestarr = vespa, goodguy, schwartz# -----------------------------------------------------------------------------
# Roles with assigned permissions
# roleName = perm1, perm2, ..., permN
# -----------------------------------------------------------------------------
[roles]
admin = *
schwartz = lightsaber:*
goodguy = winnebago:drive:eagle5

選擇了數據源,現在開始使用Shiro進行認證和訪問授權控制。

?

3. 認證
在Shiro中,認證即執行用戶登錄,讀取指定Realm連接的數據源,以驗證用戶身份的有效性與合法性。

String name = "lonestarr";
String pass = "vespa";
Subject currentUser = SecurityUtils.getSubject();
if(!currentUser.isAuthenticated()) {UsernamePasswordToken token = new UsernamePasswordToken(name, pass);token.setRememberMe(true);try {currentUser.login(token);} catch (UnknownAccountException e) {logger.error(String.format("user not found: %s", name), e);} catch(IncorrectCredentialsException e) {logger.error(String.format("user: %s pwd: %s error", name, pass), e);} catch (ConcurrentAccessException e) {logger.error(String.format("user has been authenticated: %s", name), e);} catch (AuthenticationException e) {logger.error(String.format("account except: %s", name), e);}
}
logger.info( "User [" + currentUser.getPrincipal() + "] logged in successfully." );

?

4. 訪問授權
在Shiro中,訪問授權即驗證用戶是否具備執行指定操作的權限(角色或權限驗證)。
特別地!在執行訪問授權驗證之前,必須執行用戶認證。

String role = "schwartz";
if(currentUser.hasRole(role)) {logger.info(String.format("用戶: %s 屬于角色:%s", name, role));
}else{logger.error(String.format("用戶: %s 不屬于角色:%s", name, role));
}String perm = "lightsaber:cc";
if(currentUser.isPermitted(perm)) {logger.info(String.format("用戶: %s 擁有權限:%s", name, perm));
}else {logger.error(String.format("用戶:%s 沒有權限:%s", name, perm));
}

?

5. 完整示例
詳見:https://git.oschina.net/cchanghui/test-shirocli.git

?

轉載于:https://www.cnblogs.com/nuccch/p/6780550.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/252787.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/252787.shtml
英文地址,請注明出處:http://en.pswp.cn/news/252787.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

高并發架構系列:Redis為什么是單線程、及高并發快的3大原因詳解

Redis的高并發和快速原因 1.redis是基于內存的&#xff0c;內存的讀寫速度非常快&#xff1b;2.redis是單線程的&#xff0c;省去了很多上下文切換線程的時間&#xff1b;3.redis使用多路復用技術&#xff0c;可以處理并發的連接。非阻塞IO 內部實現采用epoll&#xff0c;采用了…

2、C#基礎 - Visual Studio 的版本選擇和下載

有句話說&#xff1a;工欲善其事&#xff0c;必先利其器&#xff0c;我不推薦在學習一個語言時使用記事本練習&#xff0c;甚至說相當的排斥。當然了&#xff0c;你也可以選擇你自己喜歡的方式。本系列推薦使用的IDE為vs2017 community版&#xff0c;銀子不夠的同志不用怕&…

紅外攝像機的原理及選擇

一、紅外基本原理介紹 光是一種電磁波&#xff0c;它的波長區間從幾個納米&#xff08;1nm10-9m&#xff0c;十億分之一米&#xff09;到 1 毫米&#xff08;mm&#xff09;左右。人眼可見的只是其中一部分&#xff0c;我們稱其為可見光&#xff0c;可見光的波長范圍為 380nm …

第六章 預處理器

宏就是文字展開&#xff0c;實際中能夠展開寫出來發現錯誤。6.1 不能忽視宏定義中的空格 6.2 宏并非函數宏定義一個函數時&#xff0c;1、要把每一個參數用括號括起來2、同一時候也要把整個表達式括起來。3、要確保宏中的參數沒有副作用#define max(a,b) ((a)>(b)?(a):(b)…

oracle 數據庫中執行數據庫語句能找到數據,但是程序中卻抓取不到

oracle 數據庫中執行數據庫語句能找到數據&#xff0c;但是程序中卻抓取不到&#xff1f; 原因&#xff1a;數據庫中插入數據時沒有commit&#xff0c;執行COMMIT后就可以查詢到。轉載于:https://www.cnblogs.com/hanje/p/10140307.html

Python3經典100道練習題003

題目&#xff1a;一個整數&#xff0c;它加上100后是一個完全平方數&#xff0c;再加上268又是一個完全平方數&#xff0c;請問該數是多少&#xff1f; 方法&#xff1a;利用循環去判斷x100和x268是否為完全平方數&#xff0c;沒用使用其他函數&#xff0c;缺點運算速度慢 1 x-…

紅外攝像機

在監控市場中&#xff0c;紅外攝像機之所以那么受市場的歡迎&#xff0c;主要還是因為它有強勁的夜視性能。市場上&#xff0c;普通的彩色攝像機基本上沒有夜視能力&#xff0c;如果需要在夜晚獲得清晰的圖像&#xff0c;必須借助額外的可見光源照明才能實現。那么監控攝像機系…

P3375 【模板】KMP字符串匹配

題目描述 如題&#xff0c;給出兩個字符串s1和s2&#xff0c;其中s2為s1的子串&#xff0c;求出s2在s1中所有出現的位置。 為了減少騙分的情況&#xff0c;接下來還要輸出子串的前綴數組next。如果你不知道這是什么意思也不要問&#xff0c;去百度搜[kmp算法]學習一下就知道了。…

[譯] 用 Shadow DOM v1 和 Custom Elements v1 實現一個原生 Web Component

原文地址&#xff1a;Make a Native Web Component with Custom Elements v1 and Shadow DOM v1原文作者&#xff1a;Pearl Latteier譯文出自&#xff1a;掘金翻譯計劃本文永久鏈接&#xff1a;github.com/xitu/gold-m…譯者&#xff1a;newraina校對者&#xff1a;CoderMing假…

php 原生文件下載

1.整個網頁的html界面源碼下載: xiazai.php <html> <head> <meta charset "utf-8"> <title></title> </head> <body> <form method"post" action"xiazai.php"> <input type"submit&quo…

紅外線攝像機的選擇與使用及原理

紅外線攝像機的選擇與使用及原理 用戶使用紅外燈首先要仔細閱讀使用說明書&#xff0c;特別是為保證人身設備安全的注意事項。檢查前面所講述的配套性方面是否達到要求&#xff0c;應考慮到的影響因素是否考慮到&#xff0c;如未達到要求&#xff0c;可及時調整所用器材。 紅…

asp 之 讓實體中字段類型為DateTime的字段僅僅顯示日期不顯示時間

在我們平時的工作開發中。我們一般會遇到這種一個問題&#xff1a;某個實體的某個字段是DateTime類型的&#xff0c;但是我們在界面上僅僅想讓它顯示日期不顯示時間&#xff01;一個訂單實體&#xff1a;//訂單類public class order{//訂單IDpublic int id{get;set;}//物品IDpu…

JQ的異步文件上傳

一,view代碼 <form role"form"><div class"form-group"><label for"keyinput">選擇文件&#xff1a;</label><input type"file" name"upfile" id"upfile" /></div><div c…

紅外成像與微光成像的區別

在現有的安防技術中,微光和紅外成像是運用最廣的夜視技術.而微光成像主要運用在反恐偵查,部隊作戰的夜視儀中、而紅外夜視成像主要用于監控攝像機的夜間監控較多.   微光成像技術微光夜視技術又稱像增強技術&#xff0c;是通過帶像增強管的夜視鏡&#xff0c;對夜天光照亮的微…

實體類和數據表的映射異常(XXX is not mapping[ ])

在使用SSH框架開發過程&#xff0c;使用hibernate框架提供的工具類實現與數據庫數據交互&#xff0c;在執行cmd操作時&#xff0c;如果出現以下異常&#xff1a; org.hibernate.hql.ast.QuerySyntaxException: xxx is not mapped [from xxx] 或者 nested exception is org.hibe…

Linux下配置LVM

1 LVM介紹LVM(Logical Volume Manager)邏輯卷管理&#xff0c;它是Linux環境下對磁盤分區進行管理的一種機制&#xff0c;LVM是建立在硬盤和分區之上的一個邏輯層&#xff0c;來提高磁盤分區管理的靈活性。通過LVM系統管理員可以輕松管理磁盤分區&#xff0c;邏輯卷管理器的技術…

Python3 配置文件(configparser)(轉載)

本文由 Luzhuo 編寫,轉發請保留該信息. 原文: http://blog.csdn.net/rozol/article/details/72793304 以下代碼以Python3.6.1為例 Less is more! configparser 可以讀寫和解析注釋文件, 但是沒有寫入注釋的功能 1 #!/usr/bin/env python2 # codingutf-83 __author__ Luzhuo4 _…

激光攝像機的原理及應用

近年來&#xff0c;在安防監控領域&#xff0c;以目前視頻監控技術的發展情況&#xff0c;室內監控和白天正常環境下的監控已不是難題&#xff0c;但社會環境的發展日新月異&#xff0c;城市的發展、森林資源的不斷流失、大型項目的建設、邊防安全的守護等&#xff0c;這些環境…

Object.defineProperty 詳解

最近想了解一下Vue是怎么實現數據雙向綁定的&#xff0c;了解到是基于Object.definProperty,在此記錄一下。 Object.defineProperty  顧名思義&#xff0c;就是給對象定義一個屬性&#xff0c;總共有這么幾種&#xff1a; value  屬性的值writable  是否可改寫&#xff0…

Java 實現排序

public class Sort {public static void main(String[] args) {int data[] {43,54,123,5,98,10,7,74,5,54};System.out.println("原先數組&#xff1a;");for(int d : data) {System.out.print(d " ");}System.out.println("\n");/*System.ou…