日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

再見了shiro

jf_ro2CN3Fa ? 來源:CSDN ? 2023-01-15 11:32 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群


前言

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

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

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

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

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

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

一、準(zhǔn)備

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

1、mavan倉庫引入


org.casbin
jcasbin
1.1.0


org.casbin
jdbc-adapter
1.1.0

2、配置文件

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

其實(shí)也可以讀取數(shù)據(jù)庫的角色權(quán)限配置。所以我們可以把關(guān)于數(shù)據(jù)庫的信息提取出來,可以進(jìn)行動(dòng)態(tài)設(shè)置。

@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里進(jìn)行相關(guān)配置了。model.conf是固定的文件,之間復(fù)制過來放在新建的和src同級(jí)的文件夾下即可。policy.csv的內(nèi)容是可以從數(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 實(shí)現(xiàn)的后臺(tái)管理系統(tǒng) + 用戶小程序,支持 RBAC 動(dòng)態(tài)權(quán)限、多租戶、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能

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

二、讀取權(quán)限信息進(jìn)行初始化

我們要對(duì)Enforcer這個(gè)類初始化,加載配置文件里的信息。所以我們寫一個(gè)類實(shí)現(xiàn)InitializingBean,在容器加載的時(shí)候就初始化這個(gè)類,方便后續(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.
}

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

returnaddPolicy;
}

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

returnremovePolicy;
}

publicstaticEnforcergetEnforcer(){
returnenforcer;
}


}

在這個(gè)類里,我們注入寫好的配置類,然后轉(zhuǎn)為靜態(tài)的,在afterPropertiesSet方法里實(shí)例化Enforcer并加載policy(策略,角色權(quán)限/url對(duì)應(yīng)關(guān)系)。

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

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

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

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

publicPolicy(){
super();
}

/**
*
*@paramsub想要訪問資源的用戶或者角色
*@paramobj將要訪問的資源,可以使用*作為通配符,例如/user/*
*@paramact用戶對(duì)資源執(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、權(quán)限控制

jcasbin的權(quán)限控制非常簡(jiǎn)單,自定義一個(gè)過濾器,if判斷就可以搞定,沒錯(cuò),就這么簡(jiǎn)單。

@WebFilter(urlPatterns="/*",filterName="JCasbinAuthzFilter")
@Order(Ordered.HIGHEST_PRECEDENCE)//執(zhí)行順序,最高級(jí)別最先執(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("無權(quán)訪問");
Mapresult=newHashMap();
result.put("code",1001);
result.put("msg","用戶權(quán)限不足");
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)這個(gè)方法對(duì)用戶、訪問資源、方式進(jìn)行匹配。這里的邏輯可以根據(jù)自己的業(yè)務(wù)來實(shí)現(xiàn)。在這個(gè)過濾器之前還可以添加一個(gè)判斷用戶是否登錄的過濾器。

2、添加刪除權(quán)限

對(duì)于權(quán)限的操作,直接調(diào)用上面寫好的EnforcerFactory里對(duì)應(yīng)的方法即可。并且,可以達(dá)到同步的效果。就是不用重啟服務(wù)器或者其他任何操作,添加或刪除用戶權(quán)限后,用戶對(duì)應(yīng)的訪問就會(huì)收到影響。

@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();
}

		

寫在后面的話

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

審核編輯 :李倩


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

    關(guān)注

    0

    文章

    404

    瀏覽量

    18501
  • spring
    +關(guān)注

    關(guān)注

    0

    文章

    341

    瀏覽量

    16060
  • 過濾器
    +關(guān)注

    關(guān)注

    1

    文章

    444

    瀏覽量

    21048

原文標(biāo)題:再見了 shiro

文章出處:【微信號(hào):芋道源碼,微信公眾號(hào):芋道源碼】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    再見,機(jī)頂盒!

    電子發(fā)燒友網(wǎng)報(bào)道(文/黃山明)近日,據(jù)國家廣播電視總局消息,一體化電視全國推廣儀式正式啟動(dòng)。所謂一體化電視,就是將機(jī)頂盒功能以軟件形態(tài)內(nèi)置于電視機(jī)中,打造極簡(jiǎn)終端形態(tài),一臺(tái)電視機(jī)即可暢享海量直播、時(shí)移、回看、點(diǎn)播等全類型電視業(yè)務(wù),具備開機(jī)看直播、一個(gè)遙控器看電視、智能語音交互、超高清呈現(xiàn)功能。 ? 而伴隨著全國一體化電視推廣的正式啟動(dòng),也宣告著自上個(gè)世紀(jì)90年代末到2000年初興起的電視機(jī)頂盒,正式走向了結(jié)束。
    的頭像 發(fā)表于 04-27 14:03 ?5890次閱讀

    海光信息與青海省海南州政府洽談合作

    近日,青海省海南州委副書記、州長(zhǎng)尕瑪朋措,江蘇省對(duì)口支援海南州前方指揮部總指揮、海南州委副書記、副州長(zhǎng)戴敏捷在北京會(huì)見了海光信息總裁沙超群一行。雙方圍繞綠色算力基礎(chǔ)設(shè)施建設(shè)、國產(chǎn)算力生態(tài)構(gòu)建、算電融合創(chuàng)新等進(jìn)行深入交流,并達(dá)成多項(xiàng)務(wù)實(shí)合作意向。
    的頭像 發(fā)表于 04-15 16:07 ?323次閱讀

    請(qǐng)問JH7110硬件資料什么時(shí)候放出來?

    JH7110硬件資料什么時(shí)候放出來,會(huì)有參考demo嗎,見了好多只開源軟件,不開源硬件的了…
    發(fā)表于 03-26 08:15

    工業(yè)相機(jī)、路由器、PLC……那些藏在設(shè)備里的RJ45,選錯(cuò)了有多坑?

    RJ45網(wǎng)口太常見了,常見到很多工程師選型時(shí)隨手一勾就完事。但正是這個(gè)“不起眼”的小元件,也不可小覷。
    的頭像 發(fā)表于 03-06 19:15 ?502次閱讀
    工業(yè)相機(jī)、路由器、PLC……那些藏在設(shè)備里的RJ45,選錯(cuò)了有多坑?

    為什么會(huì)有TCP/IP協(xié)議?

    ,計(jì)算機(jī)只是單兵作戰(zhàn)并不會(huì)發(fā)揮太大的作用。 只有把它們聯(lián)合起來,電腦才會(huì)發(fā)揮出它最大的潛力。于是人們就想方設(shè)法的用電線把電腦連接到了一起。 但是簡(jiǎn)單的連到一起是遠(yuǎn)遠(yuǎn)不夠的,就好像語言不同的兩個(gè)人互相見了
    發(fā)表于 12-03 06:28

    KiCon Asia 2025 完美落幕,相約明年再見

    “ ?3 天緊湊的活動(dòng)完美落幕!一場(chǎng)培訓(xùn),16個(gè)主題演講。更重要的是,來自全球各地的喜歡 KiCad 的小伙伴們可以聚在一起,互相交流,暢所欲言。? ” ? 未能現(xiàn)場(chǎng)參加的小伙伴可以掃碼查看現(xiàn)場(chǎng)的照片: 演講的視頻和 PPT 整理后會(huì)在公眾號(hào)分享。 讓我們一起回顧下會(huì)議的過程... 11月13日 培訓(xùn) 這次培訓(xùn)比去年更精彩,Seth 同學(xué)分享了很多在文檔上找不到的技巧,帶大家完整設(shè)計(jì)了一個(gè) USB 電路。相信所有的小伙伴都受益匪淺。 11月14~15日 主題演講 1. Ki
    的頭像 發(fā)表于 11-16 11:20 ?612次閱讀
    KiCon Asia 2025 完美落幕,相約明年<b class='flag-5'>再見</b>!

    安達(dá)發(fā)|用APS自動(dòng)排程,對(duì)玻璃加工“拖期”說再見

    在競(jìng)爭(zhēng)日益激烈的制造業(yè)環(huán)境中,玻璃加工行業(yè)正面臨著前所未有的挑戰(zhàn)。多品種、小批量、短交期的訂單模式已成為常態(tài),從原片切割、磨邊、鉆孔,到鋼化、鍍膜、絲印等復(fù)雜工藝,生產(chǎn)環(huán)節(jié)環(huán)環(huán)相扣,任何一個(gè)環(huán)節(jié)的延遲都可能引發(fā)連鎖反應(yīng),導(dǎo)致訂單交付延誤、庫存積壓、生產(chǎn)成本飆升。如何打破生產(chǎn)計(jì)劃與調(diào)度的瓶頸? APS自動(dòng)排程 系統(tǒng)的引入,正成為玻璃加工企業(yè)邁向智能化、數(shù)字化管理,贏得市場(chǎng)競(jìng)爭(zhēng)力的關(guān)鍵一步。 玻璃加工行業(yè)傳統(tǒng)排
    的頭像 發(fā)表于 11-10 11:10 ?459次閱讀
    安達(dá)發(fā)|用APS自動(dòng)排程,對(duì)玻璃加工“拖期”說<b class='flag-5'>再見</b>

    東軟集團(tuán)受邀出席第三屆亞洲愿景論壇

    近日,第三屆亞洲愿景論壇(Asia New Vision Forum)在新加坡召開。期間,新加坡副總理兼貿(mào)工部長(zhǎng)顏金勇(Gan Kim Yong)出席論壇并會(huì)見了東軟集團(tuán)總裁蓋龍佳等企業(yè)代表,就亞洲經(jīng)濟(jì)的發(fā)展趨勢(shì)和挑戰(zhàn)、亞洲企業(yè)在新加坡的投資與發(fā)展等話題進(jìn)行交流。
    的頭像 發(fā)表于 09-16 14:36 ?1114次閱讀

    臺(tái)式電腦盤符不見了#

    前段時(shí)間電腦運(yùn)行速度突然變得特別慢,小毛病不斷,后來CDE盤盤符也不見了,于是就重裝了系統(tǒng),剛好了兩天,今天一開電腦就發(fā)現(xiàn)CDE盤符上有感嘆號(hào),于是做了磁盤檢查,完了說要重啟電腦,結(jié)果重啟完電腦這幾個(gè)盤符又不見了,該怎么辦?
    發(fā)表于 08-28 20:50

    廣西壯族自治區(qū)領(lǐng)導(dǎo)蒞臨有方科技參觀交流

    近日,廣西壯族自治區(qū)黨委書記、自治區(qū)人大常委會(huì)主任陳剛在南寧會(huì)見了深圳市有方科技股份有限公司董事長(zhǎng)兼總經(jīng)理王慷一行。雙方圍繞深化城市物聯(lián)感知體系建設(shè)、AI硬件終端、場(chǎng)景AI解決方案、延伸具身人形機(jī)器人產(chǎn)業(yè)鏈等方面的議題進(jìn)行了交流。
    的頭像 發(fā)表于 08-12 11:42 ?1157次閱讀

    西班牙政府考察團(tuán)點(diǎn)贊德賽西威智能工廠

    近日,德賽西威成為西班牙媒體關(guān)注的焦點(diǎn),該國政府高級(jí)官員接連組團(tuán)式現(xiàn)場(chǎng)視察并會(huì)見了德賽西威執(zhí)行副總裁凌劍輝,盛贊德賽西威位于西班牙安達(dá)盧西亞州利納雷斯市的智能工廠項(xiàng)目,高度肯定了該項(xiàng)目對(duì)推動(dòng)當(dāng)?shù)亟?jīng)濟(jì)、提升就業(yè),乃至西班牙汽車產(chǎn)業(yè)發(fā)展的重要意義。
    的頭像 發(fā)表于 07-09 14:59 ?1310次閱讀

    CYW43907系列在ModusToolbox的工程是否可以移植到Keil uVision中?

    CYW43907系列在ModusToolbox的工程是否可以移植到Keil uVision中,看見了官方推出的移植文檔,但是不知道是否支持此芯片
    發(fā)表于 07-08 06:48

    精彩回顧 | TOSUN同星2025歐洲汽車測(cè)試展圓滿落幕,期待下次再見!

    5月20-22日,全球汽車測(cè)試技術(shù)盛會(huì)——?dú)W洲汽車測(cè)試展(EuropeanAutomotiveTestingExpo2025)在德國圓滿落幕。作為汽車電子基礎(chǔ)工具鏈領(lǐng)域領(lǐng)先企業(yè),TOSUN同星攜多領(lǐng)域測(cè)試解決方案及最新發(fā)布產(chǎn)品矩陣重磅亮相,吸引了眾多國際客戶與行業(yè)專家的高度關(guān)注?,F(xiàn)場(chǎng)直擊ExhibitionSite展會(huì)期間,TOSUN同星展臺(tái)吸引了來自來自歐
    的頭像 發(fā)表于 05-23 20:06 ?826次閱讀
    精彩回顧 | TOSUN同星2025歐洲汽車測(cè)試展圓滿落幕,期待下次<b class='flag-5'>再見</b>!

    巴西總統(tǒng)盧拉會(huì)見長(zhǎng)城汽車

    近日,在華訪問的巴西總統(tǒng)盧拉會(huì)見了長(zhǎng)城汽車董事長(zhǎng)魏建軍。作為汽車產(chǎn)業(yè)的代表,魏建軍就在巴西投資布局項(xiàng)目的最新成果以及合規(guī)、誠信的經(jīng)營(yíng)理念與盧拉總統(tǒng)進(jìn)行了深入交流,盧拉總統(tǒng)對(duì)此給予了高度贊賞和支持。會(huì)談期間,雙方還就長(zhǎng)城汽車在巴西的進(jìn)一步發(fā)展達(dá)成共識(shí)。
    的頭像 發(fā)表于 05-16 15:51 ?831次閱讀
    海口市| 屏山县| 溧水县| 铁岭县| 景宁| 婺源县| 枝江市| 临高县| 百色市| 汤原县| 青铜峡市| 岫岩| 安康市| 武川县| 宿迁市| 常德市| 景谷| 江华| 青龙| 佛坪县| 丹棱县| 芒康县| 萨迦县| 广宁县| 齐河县| 哈尔滨市| 东山县| 越西县| 定远县| 乌鲁木齐市| 台北县| 保靖县| 屏东县| 嘉黎县| 临汾市| 庆安县| 收藏| 连州市| 铜鼓县| 鹿泉市| 拉萨市|