0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

再見了shiro

jf_ro2CN3Fa ? 來源:CSDN ? 2023-01-15 11:32 ? 次閱讀


前言

作為一名后臺開發(fā)人員,權限這個名詞應該算是特別熟悉的了。就算是java里的類也有 public、private 等“權限”之分。之前項目里一直使用shiro作為權限管理的框架。說實話,shiro的確挺強大的,但是它也有很多不好的地方。shiro默認的登錄地址還是login.jsp,前后端分離模式使用shiro還要重寫好多類;手機端存儲用戶信息、保持登錄狀態(tài)等等,對shiro來說也是一個難題。

在分布式項目里,比如電商項目,其實不太需要明確的權限劃分,說白了,我認為沒必要做太麻煩的權限管理,一切從簡。何況shiro對于springCloud等各種分布式框架來說,簡直就是“災難”。每個子系統(tǒng)里都要寫點shiro的東西,慢慢的,越來越惡心。zuul網(wǎng)關就在這里大顯身手了,控制用戶的登錄,鑒定用戶的權限等等。zuul網(wǎng)關控制用戶登錄,鑒權以后再詳說。以上拙見。

然后最近我發(fā)現(xiàn)了另一個權限框架jcasbin,雖然網(wǎng)上還沒有很多關于博客,但是我看了一會就可以使用了。

順手貼上github地址:https://github.com/casbin/jcasbin

基于 Spring Boot + MyBatis Plus + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權限、多租戶、數(shù)據(jù)權限、工作流、三方登錄、支付、短信、商城等功能

  • 項目地址:https://github.com/YunaiV/ruoyi-vue-pro
  • 視頻教程:https://doc.iocoder.cn/video/

一、準備

基于springboot1.5.10,但是和springboot關系不太大,所以版本可以忽略,用你熟悉的springboot版本就行。

1、mavan倉庫引入


org.casbin
jcasbin
1.1.0


org.casbin
jdbc-adapter
1.1.0

2、配置文件

jcasbin把用戶的角色、權限信息(訪問路徑)放置在配置文件里,然后通過輸入流讀取配置文件。主要有兩個配置文件:model.confpolicy.csv。簡單的使用GitHub里都講了,在此就不再贅述了。

其實也可以讀取數(shù)據(jù)庫的角色權限配置。所以我們可以把關于數(shù)據(jù)庫的信息提取出來,可以進行動態(tài)設置。

@Configuration
@ConfigurationProperties(prefix="org.jcasbin")
publicclassEnforcerConfigProperties{

privateStringurl;

privateStringdriverClassName;

privateStringusername;

privateStringpassword;

privateStringmodelPath;

publicStringgetUrl(){
returnurl;
}

publicvoidsetUrl(Stringurl){
this.url=url;
}

publicStringgetDriverClassName(){
returndriverClassName;
}

publicvoidsetDriverClassName(StringdriverClassName){
this.driverClassName=driverClassName;
}

publicStringgetUsername(){
returnusername;
}

publicvoidsetUsername(Stringusername){
this.username=username;
}

publicStringgetPassword(){
returnpassword;
}

publicvoidsetPassword(Stringpassword){
this.password=password;
}

publicStringgetModelPath(){
returnmodelPath;
}

publicvoidsetModelPath(StringmodelPath){
this.modelPath=modelPath;
}

@Override
publicStringtoString(){
return"EnforcerConfigProperties[url="+url+",driverClassName="+driverClassName+",username="
+username+",password="+password+",modelPath="+modelPath+"]";
}

}

這樣我們就可以在application.properties里進行相關配置了。model.conf是固定的文件,之間復制過來放在新建的和src同級的文件夾下即可。policy.csv的內容是可以從數(shù)據(jù)庫讀取的。

org.jcasbin.url=jdbc//localhost:3306/casbin?useSSL=false
org.jcasbin.driver-class-name=com.mysql.jdbc.Driver
org.jcasbin.username=root
org.jcasbin.password=root
org.jcasbin.model-path=conf/authz_model.conf

基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權限、多租戶、數(shù)據(jù)權限、工作流、三方登錄、支付、短信、商城等功能

  • 項目地址:https://github.com/YunaiV/yudao-cloud
  • 視頻教程:https://doc.iocoder.cn/video/

二、讀取權限信息進行初始化

我們要對Enforcer這個類初始化,加載配置文件里的信息。所以我們寫一個類實現(xiàn)InitializingBean,在容器加載的時候就初始化這個類,方便后續(xù)的使用。

@Component
publicclassEnforcerFactoryimplementsInitializingBean{

privatestaticEnforcerenforcer;

@Autowired
privateEnforcerConfigPropertiesenforcerConfigProperties;
privatestaticEnforcerConfigPropertiesconfig;

@Override
publicvoidafterPropertiesSet()throwsException{
config=enforcerConfigProperties;
//從數(shù)據(jù)庫讀取策略
JDBCAdapterjdbcAdapter=newJDBCAdapter(config.getDriverClassName(),config.getUrl(),config.getUsername(),
config.getPassword(),true);
enforcer=newEnforcer(config.getModelPath(),jdbcAdapter);
enforcer.loadPolicy();//LoadthepolicyfromDB.
}

/**
*添加權限
*@parampolicy
*@return
*/
publicstaticbooleanaddPolicy(Policypolicy){
booleanaddPolicy=enforcer.addPolicy(policy.getSub(),policy.getObj(),policy.getAct());
enforcer.savePolicy();

returnaddPolicy;
}

/**
*刪除權限
*@parampolicy
*@return
*/
publicstaticbooleanremovePolicy(Policypolicy){
booleanremovePolicy=enforcer.removePolicy(policy.getSub(),policy.getObj(),policy.getAct());
enforcer.savePolicy();

returnremovePolicy;
}

publicstaticEnforcergetEnforcer(){
returnenforcer;
}


}

在這個類里,我們注入寫好的配置類,然后轉為靜態(tài)的,在afterPropertiesSet方法里實例化Enforcer并加載policy(策略,角色權限/url對應關系)。

同時又寫了兩個方法,用來添加和刪除policy,Policy是自定的一個類,對官方使用的集合/數(shù)組進行了封裝。

publicclassPolicy{
/**想要訪問資源的用戶或者角色*/
privateStringsub;

/**將要訪問的資源,可以使用*作為通配符,例如/user/**/
privateStringobj;

/**用戶對資源執(zhí)行的操作。HTTP方法,GET、POST、PUT、DELETE等,可以使用*作為通配符*/
privateStringact;

publicPolicy(){
super();
}

/**
*
*@paramsub想要訪問資源的用戶或者角色
*@paramobj將要訪問的資源,可以使用*作為通配符,例如/user/*
*@paramact用戶對資源執(zhí)行的操作。HTTP方法,GET、POST、PUT、DELETE等,可以使用*作為通配符
*/
publicPolicy(Stringsub,Stringobj,Stringact){
super();
this.sub=sub;
this.obj=obj;
this.act=act;
}

publicStringgetSub(){
returnsub;
}

publicvoidsetSub(Stringsub){
this.sub=sub;
}

publicStringgetObj(){
returnobj;
}

publicvoidsetObj(Stringobj){
this.obj=obj;
}

publicStringgetAct(){
returnact;
}

publicvoidsetAct(Stringact){
this.act=act;
}

@Override
publicStringtoString(){
return"Policy[sub="+sub+",obj="+obj+",act="+act+"]";
}

}

三、使用

1、權限控制

jcasbin的權限控制非常簡單,自定義一個過濾器,if判斷就可以搞定,沒錯,就這么簡單。

@WebFilter(urlPatterns="/*",filterName="JCasbinAuthzFilter")
@Order(Ordered.HIGHEST_PRECEDENCE)//執(zhí)行順序,最高級別最先執(zhí)行,int從小到大
publicclassJCasbinAuthzFilterimplementsFilter{

privatestaticfinalLoggerlog=LoggerFactory.getLogger(JCasbinAuthzFilter.class);

privatestaticEnforcerenforcer;

@Override
publicvoidinit(FilterConfigfilterConfig)throwsServletException{
}

@Override
publicvoiddoFilter(ServletRequestservletRequest,ServletResponseservletResponse,FilterChainchain)
throwsIOException,ServletException{
HttpServletRequestrequest=(HttpServletRequest)servletRequest;
HttpServletResponseresponse=(HttpServletResponse)servletResponse;

Stringuser=request.getParameter("username");
Stringpath=request.getRequestURI();
Stringmethod=request.getMethod();

enforcer=EnforcerFactory.getEnforcer();
if(path.contains("anon")){
chain.doFilter(request,response);
}elseif(enforcer.enforce(user,path,method)){
chain.doFilter(request,response);
}else{
log.info("無權訪問");
Mapresult=newHashMap();
result.put("code",1001);
result.put("msg","用戶權限不足");
result.put("data",null);
response.setCharacterEncoding("UTF-8");
response.setContentType("application/json");
response.getWriter().write(JSONObject.toJSONString(result,SerializerFeature.WriteMapNullValue));
}

}

@Override
publicvoiddestroy(){

}

}

主要是用enforcer.enforce(user, path, method)這個方法對用戶、訪問資源、方式進行匹配。這里的邏輯可以根據(jù)自己的業(yè)務來實現(xiàn)。在這個過濾器之前還可以添加一個判斷用戶是否登錄的過濾器。

2、添加刪除權限

對于權限的操作,直接調用上面寫好的EnforcerFactory里對應的方法即可。并且,可以達到同步的效果。就是不用重啟服務器或者其他任何操作,添加或刪除用戶權限后,用戶對應的訪問就會收到影響。

@PutMapping("/anon/role/per")
publicResultBOaddPer(){

EnforcerFactory.addPolicy(newPolicy("alice","/user/list","*"));

returnResultTool.success();
}

@DeleteMapping("/anon/role/per")
publicResultBOdeletePer(){

EnforcerFactory.removePolicy(newPolicy("alice","/user/list","*"));

returnResultTool.success();
}

		

寫在后面的話

其實可以把jcasbin和SpringCloud的zuul結合來實現(xiàn)用戶的統(tǒng)一登錄和權限控制。自定義一個過濾器繼承ZuulFilter即可,其他地方基本沒啥區(qū)別。

審核編輯 :李倩


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 框架
    +關注

    關注

    0

    文章

    396

    瀏覽量

    17268
  • spring
    +關注

    關注

    0

    文章

    335

    瀏覽量

    14258
  • 過濾器
    +關注

    關注

    1

    文章

    419

    瀏覽量

    19381

原文標題:再見了 shiro

文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    使用LMH6401遇見了通頻帶不平坦的問題,怎么解決?

    我在使用TI公司的DVGA LMH6401的時候遇見了通頻帶不平坦的問題。設計電路為三級LMH6401+三級LMH6401,希望實現(xiàn)了80多dB的動態(tài)調節(jié)范圍,其中遇到了兩個問題,第一個就是通頻帶
    發(fā)表于 09-05 06:18

    MDK5.23將C/C++的字體由系統(tǒng)默認的Courier New切換為Consolas字體,再切換回去Courier New字體選項不見了

    MDK5.23,將C/C++的字體由系統(tǒng)默認的Courier New切換為Consolas字體,想再切換回去的時候,發(fā)現(xiàn)Courier New字體選項居然不見了??百思不得其解,這難道還有什么特殊的地方??求助??!
    發(fā)表于 04-23 07:09

    ST-Link驅動不見了怎么解決?

    用了很久的ST-Link驅動突然不見了,重新安裝設備管理器里面也沒有,電腦重啟也沒用,到底怎么了,應該怎么辦?[/tr]
    發(fā)表于 03-18 06:37

    一個簡單的Shiro RCE檢測和利用腳本

    一個簡單的Shiro RCE檢測和利用腳本。
    的頭像 發(fā)表于 01-09 09:46 ?483次閱讀

    揮手2023,我們2024再見!

    光學儀器儀器儀表
    上海嫦娥光學儀器科技有限公司
    發(fā)布于 :2024年01月02日 11:19:35

    揮別2023,展望2024

    —— Microchip愿與您攜手并進,共創(chuàng)未來 Microchip 總裁兼首席執(zhí)行官 GaneshMoorthy 就要和2023說再見了。值此辭舊迎新之際,我要向Microchip的全體員工、客戶
    的頭像 發(fā)表于 12-27 13:55 ?1374次閱讀

    AD9548/PCBZ評估板的電源適配器是多少V和多少A的?

    我想問一下AD9548/PCBZ評估板的電源適配器是多少V和多少A的,因為前段時間我的電源適配器不見了
    發(fā)表于 11-15 07:27

    #共建FPGA開發(fā)者技術社區(qū),為FPGA生態(tài)點贊#

    今天玩玩紫光的riscv軟核,遇見了編碼問題導致的串口打印亂碼,哈哈哈
    發(fā)表于 11-08 14:06

    STemWin怎么使用大號字體?

    STemWin 怎么使用大號字體, 看代碼 GUI_SetDefaultFont 是 6x8 的字體,可是修改字體,那一堆宏,只有 6x8 有用,其他的宏都不管用。 怎么樣使用大一號的字體,這個字體太小太小了,正點原子 4.3 寸屏,6x8字體幾乎都看不見了。
    發(fā)表于 11-01 07:19

    求助,關于MDK字體切換問題

    MDK5.23,將C/C++的字體由系統(tǒng)默認的Courier New切換為Consolas字體,想再切換回去的時候,發(fā)現(xiàn)Courier New字體選項居然不見了??百思不得其解,這難道還有什么特殊的地方??求助?。?
    發(fā)表于 10-25 07:10

    雷軍稱小米澎湃OS將逐步接替MIUI 小米14優(yōu)先搭載

    小米推出全新操作系統(tǒng)澎湃OS;按照雷軍的說法從今天開始,我們要逐步跟 MIUI 說再見了!最新款的小米14 系列將率先搭載澎湃OS,而且其他小米手機都會逐步更新。 17日上午,小米董事長兼CEO雷軍
    的頭像 發(fā)表于 10-17 16:38 ?957次閱讀
    雷軍稱小米澎湃OS將逐步接替MIUI 小米14優(yōu)先搭載

    關于子面板調用?

    剛入手,想做一個界面切換的功能,子面板調用的時候發(fā)現(xiàn)單獨運行子面板的時候子面板在正中間,但是放在其他界面調用的時候就感覺原點不一樣,整個界面不見了或者不在正中間。!!研究了一天爺沒找到解決辦法。有沒有大哥來個詳細說明的?1696770748657.jpg
    發(fā)表于 10-08 21:14

    Shiro功能介紹

    記得做的第一個Web項目,系統(tǒng)認證授權這塊就是基于Shiro實現(xiàn)的,當時也是第一次接觸到這種類型的框架,同時是基于Spring做的集成,并且相關的配置都已經(jīng)是定制好的,只需要我們根據(jù)項目情況對極少
    的頭像 發(fā)表于 10-08 15:07 ?410次閱讀
    <b class='flag-5'>Shiro</b>功能介紹

    shiro如何實現(xiàn)Web應用認證

    前面簡單介紹了shiro這個框架的一些基本知識,包括其架構模型,主要的功能,關鍵名稱的含義,以及核心模塊和對應的接口定義。 開始的話 今天我們從一個簡單示例,先了解使用shiro實現(xiàn)Web應用認證
    的頭像 發(fā)表于 10-08 14:53 ?423次閱讀
    <b class='flag-5'>shiro</b>如何實現(xiàn)Web應用認證

    ?這次可能真要和HTTP說再見了

    這意味著,當前大多數(shù)的網(wǎng)站流量都經(jīng)過了加密和身份驗證,可以免受一些黑客的網(wǎng)絡攻擊。但是,現(xiàn)在仍有 5-10% 的流量頑固地保留在 HTTP 上,從而讓攻擊者能夠竊聽或更改這些請求的數(shù)據(jù)。
    的頭像 發(fā)表于 09-23 10:21 ?359次閱讀
    ?這次可能真要和HTTP說<b class='flag-5'>再見了</b>