欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot+Vue前后端分離,使用SpringSecurity完美處理權(quán)限問題的解決方法

 更新時(shí)間:2018年01月09日 10:45:18   作者:江南一點(diǎn)雨  
這篇文章主要介紹了SpringBoot+Vue前后端分離,使用SpringSecurity完美處理權(quán)限問題,需要的朋友可以參考下

當(dāng)前后端分離時(shí),權(quán)限問題的處理也和我們傳統(tǒng)的處理方式有一點(diǎn)差異。筆者前幾天剛好在負(fù)責(zé)一個(gè)項(xiàng)目的權(quán)限管理模塊,現(xiàn)在權(quán)限管理模塊已經(jīng)做完了,我想通過5-6篇文章,來(lái)介紹一下項(xiàng)目中遇到的問題以及我的解決方案,希望這個(gè)系列能夠給小伙伴一些幫助。本系列文章并不是手把手的教程,主要介紹了核心思路并講解了核心代碼,完整的代碼小伙伴們可以在GitHub上star并clone下來(lái)研究。另外,原本計(jì)劃把項(xiàng)目跑起來(lái)放到網(wǎng)上供小伙伴們查看,但是之前買服務(wù)器為了省錢,內(nèi)存只有512M,兩個(gè)應(yīng)用跑不起來(lái)(已經(jīng)有一個(gè)V部落開源項(xiàng)目 在運(yùn)行),因此小伙伴們只能將就看一下下面的截圖了,文末有部署教程,部署到本地也可以查看完整效果。

本文我們先不聊具體實(shí)現(xiàn),我先來(lái)介紹一下我這個(gè)權(quán)限管理模塊的一個(gè)整體架構(gòu),以及最終呈現(xiàn)出來(lái)的效果。

數(shù)據(jù)庫(kù)設(shè)計(jì)

權(quán)限數(shù)據(jù)庫(kù)主要包含了五張表,分別是資源表、角色表、用戶表、資源角色表、用戶角色表,數(shù)據(jù)庫(kù)關(guān)系模型如下:

 

關(guān)于這個(gè)表,我說如下幾點(diǎn):

1.hr表是用戶表,存放了用戶的基本信息。

2.role是角色表,name字段表示角色的英文名稱,按照SpringSecurity的規(guī)范,將以 ROLE_ 開始,nameZh字段表示角色的中文名稱。

3.menu表是一個(gè)資源表,該表涉及到的字段有點(diǎn)多,由于我的前端采用了Vue來(lái)做,因此當(dāng)用戶登錄成功之后,系統(tǒng)將根據(jù)用戶的角色動(dòng)態(tài)加載需要的模塊,所有模塊的信息將保存在menu表中,menu表中的path、component、iconCls、keepAlive、requireAuth等字段都是Vue-Router中需要的字段,也就是說menu中的數(shù)據(jù)到時(shí)候會(huì)以json的形式返回給前端,再由vue動(dòng)態(tài)更新router,menu中還有一個(gè)字段url,表示一個(gè)url pattern,即路徑匹配規(guī)則,假設(shè)有一個(gè)路徑匹配規(guī)則為 /admin/** ,那么當(dāng)用戶在客戶端發(fā)起一個(gè) /admin/user 的請(qǐng)求,將被 /admin/** 攔截到,系統(tǒng)再去查看這個(gè)規(guī)則對(duì)應(yīng)的角色是哪些,然后再去查看該用戶是否具備相應(yīng)的角色,進(jìn)而判斷該請(qǐng)求是否合法。

下圖分別是用戶表、角色表以及資源表中的部分?jǐn)?shù)據(jù)(數(shù)據(jù)庫(kù)腳本可以在文末的項(xiàng)目地址中下載,位置 resources/vhr.sql ):

整體效果

首先,不同的用戶在登錄成功之后,根據(jù)不同的角色,會(huì)看到不同的系統(tǒng)菜單,完整菜單如下:

 

不同用戶登錄上來(lái)之后,可能看到的會(huì)有差異,如下:

 

每個(gè)用戶的角色是由系統(tǒng)管理員進(jìn)行分配的,系統(tǒng)管理員給用戶分配角色的頁(yè)面如下:

 

系統(tǒng)管理員也可以管理不同角色可以操作的資源,頁(yè)面如下:

 

其他的刪除、搜索等一些瑣碎的功能我這里就不再一一介紹了。

項(xiàng)目地址

由于商業(yè)協(xié)議,原本的項(xiàng)目不能共享給各位小伙伴,因此我專門做了一個(gè)開源項(xiàng)目,這個(gè)項(xiàng)目的功能整體來(lái)說比較多,但是考慮到這個(gè)系列的文章主要是向大家介紹權(quán)限管理模塊,因此其他模塊都被我暫時(shí)閹割掉了,不過小伙伴們可以放心,權(quán)限管理模塊的代碼一行都沒有刪除,涉及到權(quán)限管理的代碼和數(shù)據(jù)都是完整的,可以直接運(yùn)行的。小伙伴將以管理員的身份登錄到后臺(tái)系統(tǒng),登錄成功之后,依次點(diǎn)擊 系統(tǒng)管理->基礎(chǔ)信息設(shè)置->權(quán)限組 ,即可配置不同角色可以操作的資源;然后依次點(diǎn)擊 系統(tǒng)管理->操作員管理 ,即可管理每一位操作員的角色。

項(xiàng)目地址: https://github.com/lenve/vhr

快速部署

1.clone項(xiàng)目到本地 git@github.com:lenve/vhr.git

2.數(shù)據(jù)庫(kù)腳本放在hrserver項(xiàng)目的resources目錄下,在MySQL中執(zhí)行數(shù)據(jù)庫(kù)腳本

3.數(shù)據(jù)庫(kù)配置在hrserver項(xiàng)目的resources目錄下的application.properties文件中

4.在IntelliJ IDEA中運(yùn)行hrserver項(xiàng)目

OK,至此,服務(wù)端就啟動(dòng)成功了,此時(shí)我們直接在地址欄輸入 http://localhost:8082/index.html 即可訪問我們的項(xiàng)目,如果要做二次開發(fā),請(qǐng)繼續(xù)看第五、六步。

5.進(jìn)入到vuehr目錄中,在命令行依次輸入如下命令:

# 安裝依賴
npm install
# 在 localhost:8080 啟動(dòng)項(xiàng)目
npm run dev

由于我在vuehr項(xiàng)目中已經(jīng)配置了端口轉(zhuǎn)發(fā),將數(shù)據(jù)轉(zhuǎn)發(fā)到SpringBoot上,因此項(xiàng)目啟動(dòng)之后,在瀏覽器中輸入 http://localhost:8080 就可以訪問我們的前端項(xiàng)目了,所有的請(qǐng)求通過端口轉(zhuǎn)發(fā)將數(shù)據(jù)傳到SpringBoot中(注意此時(shí)不要關(guān)閉SpringBoot項(xiàng)目)。

6.最后可以用WebStorm等工具打開vuehr項(xiàng)目,繼續(xù)開發(fā),開發(fā)完成后,當(dāng)項(xiàng)目要上線時(shí),依然進(jìn)入到vuehr目錄,然后執(zhí)行如下命令:

npm run build

該命令執(zhí)行成功之后,vuehr目錄下生成一個(gè)dist文件夾,將該文件夾中的兩個(gè)文件static和index.html拷貝到SpringBoot項(xiàng)目中resources/static/目錄下,然后就可以像第4步那樣直接訪問了。

步驟5中需要大家對(duì)NodeJS、NPM等有一定的使用經(jīng)驗(yàn),不熟悉的小伙伴可以先自行搜索學(xué)習(xí)下,推薦 Vue官方教程 。

注意事項(xiàng)

再次強(qiáng)調(diào),這只是一個(gè)權(quán)限管理功能模塊,運(yùn)行后只有權(quán)限管理功能是完整的。小伙伴們?cè)诒镜夭渴鸪晒χ螅梢孕薷拿恳粋€(gè)用戶的角色以及每一個(gè)角色可以操作的資源,修改成功之后,注銷登錄,再以被修改的用戶身份登錄,即可看到菜單變化。

總結(jié)

以上所述是小編給大家介紹的SpringBoot+Vue前后端分離,使用SpringSecurity完美處理權(quán)限問題的解決方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue實(shí)現(xiàn)簡(jiǎn)單放大鏡效果

    vue實(shí)現(xiàn)簡(jiǎn)單放大鏡效果

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)簡(jiǎn)單放大鏡效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue數(shù)字類型過濾器的示例代碼

    vue數(shù)字類型過濾器的示例代碼

    本篇文章主要介紹了vue數(shù)字類型過濾器的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-09-09
  • Vue3實(shí)現(xiàn)Emoji表情的四種方案

    Vue3實(shí)現(xiàn)Emoji表情的四種方案

    聊天工具的項(xiàng)目開發(fā)到了表情功能,由于目前會(huì)話的輸入?yún)^(qū)域使用的是 textarea 而非富文本編輯器,所以表情功能也需要兼顧 textarea 進(jìn)行開發(fā),本文給大家簡(jiǎn)單聊聊幾種表情的實(shí)現(xiàn)方,感興趣的小伙伴一起來(lái)看看吧
    2025-01-01
  • vue2.0實(shí)戰(zhàn)之使用vue-cli搭建項(xiàng)目(2)

    vue2.0實(shí)戰(zhàn)之使用vue-cli搭建項(xiàng)目(2)

    這篇文章主要為大家詳細(xì)介紹了vue2.0實(shí)戰(zhàn)第二篇使用vue-cli搭建項(xiàng)目,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Vue中使用matomo進(jìn)行訪問流量統(tǒng)計(jì)的實(shí)現(xiàn)

    Vue中使用matomo進(jìn)行訪問流量統(tǒng)計(jì)的實(shí)現(xiàn)

    這篇文章主要介紹了Vue中使用matomo進(jìn)行訪問流量統(tǒng)計(jì)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • vue中router.beforeEach()的簡(jiǎn)單用法舉例

    vue中router.beforeEach()的簡(jiǎn)單用法舉例

    router.beforeEach()一般用來(lái)做一些進(jìn)入頁(yè)面的限制,比如沒有登錄,就不能進(jìn)入某些頁(yè)面,只有登錄了之后才有權(quán)限查看某些頁(yè)面,下面這篇文章主要給大家介紹了關(guān)于vue中router.beforeEach()的簡(jiǎn)單用法舉例,需要的朋友可以參考下
    2023-01-01
  • Vue中xlsx的使用方法指南

    Vue中xlsx的使用方法指南

    這篇文章主要給大家介紹了關(guān)于Vue中xlsx的使用方法指南,有很多辦法都可以實(shí)現(xiàn),其中最簡(jiǎn)單的還是使用插件xlsx,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • Vue3之toRefs和toRef在reactive中的一些應(yīng)用方式

    Vue3之toRefs和toRef在reactive中的一些應(yīng)用方式

    這篇文章主要介紹了Vue3之toRefs和toRef在reactive中的一些應(yīng)用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue.js中extend選項(xiàng)和delimiters選項(xiàng)的比較

    Vue.js中extend選項(xiàng)和delimiters選項(xiàng)的比較

    這篇文章主要介紹了Vue.js中extend選項(xiàng)和delimiters選項(xiàng)的比較的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • Vue2響應(yīng)式系統(tǒng)之嵌套

    Vue2響應(yīng)式系統(tǒng)之嵌套

    這篇文章主要介紹了Vue響應(yīng)式系統(tǒng)之嵌套,我們?cè)陂_發(fā)中肯定存在組件嵌套組件的情況,下文將舉例說明情況,需要的小伙伴可以參考一下
    2022-04-04

最新評(píng)論