千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > shirospringboot怎么操作

shirospringboot怎么操作

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-08-09 18:38:30 1691577510

Shiro是一個強大且靈活的Java安全框架,它提供了身份驗證、授權(quán)、加密和會話管理等功能,可以幫助開發(fā)者輕松地實現(xiàn)應(yīng)用程序的安全控制。在Spring Boot項目中使用Shiro可以更加方便地集成和配置。

下面是使用Shiro和Spring Boot進行操作的步驟:

1. 添加Shiro和Spring Boot的依賴:在項目的pom.xml文件中添加Shiro和Spring Boot的相關(guān)依賴。例如:

org.apache.shiro

shiro-spring-boot-starter

1.7.1

2. 配置Shiro:在Spring Boot項目的配置文件(application.properties或application.yml)中添加Shiro的相關(guān)配置。例如:

Shiro配置

shiro:

配置Shiro的過濾器鏈

filter-chain-definition-map:

允許匿名訪問的URL

/login: anon

/logout: anon

需要身份驗證才能訪問的URL

/admin/**: authc

配置Shiro的Realm

realm:

自定義的Realm類

class-name: com.example.MyRealm

3. 創(chuàng)建自定義的Realm類:在項目中創(chuàng)建一個繼承自org.apache.shiro.realm.AuthorizingRealm的自定義Realm類,并實現(xiàn)其中的抽象方法。在該類中,可以進行用戶身份驗證和授權(quán)的邏輯處理。例如:

public class MyRealm extends AuthorizingRealm {

// 用戶身份驗證

@Override

protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {

// 獲取用戶輸入的用戶名和密碼

String username = (String) token.getPrincipal();

String password = new String((char[]) token.getCredentials());

// 根據(jù)用戶名查詢數(shù)據(jù)庫或其他數(shù)據(jù)源,獲取用戶信息

User user = userService.findByUsername(username);

// 如果用戶不存在或密碼不匹配,拋出異常

if (user == null || !password.equals(user.getPassword())) {

throw new IncorrectCredentialsException();

}

// 驗證通過,返回身份驗證信息

return new SimpleAuthenticationInfo(user, password, getName());

}

// 用戶授權(quán)

@Override

protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {

// 獲取當(dāng)前登錄用戶

User user = (User) principals.getPrimaryPrincipal();

// 查詢用戶的角色和權(quán)限信息

Set roles = userService.findRolesByUsername(user.getUsername());

Set permissions = userService.findPermissionsByUsername(user.getUsername());

// 創(chuàng)建授權(quán)信息對象

SimpleAuthorizationInfo info = new SimpleAuthorizationInfo();

info.setRoles(roles);

info.setStringPermissions(permissions);

return info;

}

4. 在需要進行身份驗證和授權(quán)的地方使用Shiro的注解:在需要進行身份驗證和授權(quán)的Controller類或方法上使用Shiro的注解,例如@RequiresAuthentication、@RequiresRoles@RequiresPermissions等。這樣,只有通過身份驗證和授權(quán)的用戶才能訪問相應(yīng)的接口或頁面。

以上就是使用Shiro和Spring Boot進行操作的基本步驟。通過配置Shiro的過濾器鏈和自定義Realm類,可以實現(xiàn)對URL的訪問控制和用戶權(quán)限管理??梢愿鶕?jù)具體需求進行更多的配置和擴展,例如使用RememberMe功能、自定義登錄頁面等。

希望以上內(nèi)容能夠幫助你理解和操作Shiro在Spring Boot項目中的使用。如果還有其他問題,請隨時提問。

千鋒教育擁有多年IT培訓(xùn)服務(wù)經(jīng)驗,開設(shè)Java培訓(xùn)、web前端培訓(xùn)大數(shù)據(jù)培訓(xùn),python培訓(xùn)、軟件測試培訓(xùn)等課程,采用全程面授高品質(zhì)、高體驗教學(xué)模式,擁有國內(nèi)一體化教學(xué)管理及學(xué)員服務(wù),想獲取更多IT技術(shù)干貨請關(guān)注千鋒教育IT培訓(xùn)機構(gòu)官網(wǎng)。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT