詳解vue身份認證管理和租戶管理
概述
功能模塊的開發(fā)往往是最容易的,但是要處理好每個細節(jié)就不容易了。就拿這里的身份認證管理模塊來說,看似很簡單,因為后端接口都是ABP模板里現(xiàn)成的,前端部分無非就是寫界面,調(diào)接口,綁數(shù)據(jù);但是看一下ABP Angular版本的代碼,就會發(fā)現(xiàn)他其實是有很多細節(jié)方面的處理的。
回到vue,因為前端部分的代碼文件太多,下面只列出一些需要注意的細節(jié),其他的像vue組件、表格、表單、數(shù)據(jù)綁定、接口請求之類的其實都差不多就不說了。
按鈕級權(quán)限
前面章節(jié)中實現(xiàn)了菜單權(quán)限的控制,按鈕權(quán)限的道理也是一樣的。判斷abpConfig.auth.grantedPolicies是否包含某個權(quán)限,然后在組件中使用v-if渲染就好了。
src\utils\abp.js:
export function checkPermission(policy) { const abpConfig = store.getters.abpConfig; if (abpConfig.auth.grantedPolicies[policy]) { return true; } else { return false; } }
src\views\identity\roles.vue:
<el-button class="filter-item" style="margin-left: 10px;" type="primary" icon="el-icon-edit" @click="handleCreate" v-if="checkPermission('AbpIdentity.Roles.Create')" > {{ $t("AbpIdentity['NewRole']") }} </el-button>
身份認證管理
角色和用戶的增刪改查就不說了,這里要注意一下權(quán)限管理。用戶和角色都需要用到權(quán)限管理,在ABP Angular版中是一個獨立的permission-management模塊。我這里也把他作為一個公用組件,根據(jù)providerName來區(qū)分,"R"是角色權(quán)限,"U"是用戶權(quán)限。
R/U權(quán)限
他們有一點區(qū)別,用戶權(quán)限可能來自于角色權(quán)限,所以用戶中的權(quán)限需要顯示是來自哪個providerName和providerKey,如果來自其他provider則disabled,不可以修改。
src\views\identity\components\permission-management.vue:
<el-form label-position="top"> <el-tabs tab-position="left"> <el-tab-pane v-for="group in permissionData.groups" :key="group.name" :label="group.displayName" > <el-form-item :label="group.displayName"> <el-tree ref="permissionTree" :data="transformPermissionTree(group.permissions)" :props="treeDefaultProps" show-checkbox check-strictly node-key="name" default-expand-all /> </el-form-item> </el-tab-pane> </el-tabs> </el-form>
transformPermissionTree(permissions, name = null) { let arr = []; if (!permissions || !permissions.some(v => v.parentName == name)) return arr; const parents = permissions.filter(v => v.parentName == name); for (let i in parents) { let label = ''; if (this.permissionsQuery.providerName == "R") { label = parents[i].displayName; } else if (this.permissionsQuery.providerName == "U") { label = parents[i].displayName + " " + parents[i].grantedProviders.map(provider => { return `${provider.providerName}: ${provider.providerKey}`; }); } arr.push({ name: parents[i].name, label, disabled: this.isGrantedByOtherProviderName( parents[i].grantedProviders ), children: this.transformPermissionTree(permissions, parents[i].name) }); } return arr; }, isGrantedByOtherProviderName(grantedProviders) { if (grantedProviders.length) { return ( grantedProviders.findIndex( p => p.providerName !== this.permissionsQuery.providerName ) > -1 ); } return false; }
權(quán)限刷新
還有一個細節(jié)問題,如果正在修改的權(quán)限影響到了當前用戶,如何立即生效。
src\views\identity\components\permission-management.vue:
updatePermissions(this.permissionsQuery, { permissions: tempData }).then( () => { this.dialogPermissionFormVisible = false; this.$notify({ title: this.$i18n.t("HelloAbp['Success']"), message: this.$i18n.t("HelloAbp['SuccessMessage']"), type: "success", duration: 2000 }); fetchAppConfig( this.permissionsQuery.providerKey, this.permissionsQuery.providerName ); } );
src\utils\abp.js:
function shouldFetchAppConfig(providerKey, providerName) { const currentUser = store.getters.abpConfig.currentUser; if (providerName === "R") return currentUser.roles.some(role => role === providerKey); if (providerName === "U") return currentUser.id === providerKey; return false; } export function fetchAppConfig(providerKey, providerName) { if (shouldFetchAppConfig(providerKey, providerName)) { store.dispatch("app/applicationConfiguration").then(abpConfig => { resetRouter(); store.dispatch("user/setRoles", abpConfig.currentUser.roles); const grantedPolicies = abpConfig.auth.grantedPolicies; // generate accessible routes map based on grantedPolicies store .dispatch("permission/generateRoutes", grantedPolicies) .then(accessRoutes => { // dynamically add accessible routes router.addRoutes(accessRoutes); }); // reset visited views and cached views //store.dispatch("tagsView/delAllViews", null, { root: true }); }); } }
還有很多需要注意的,比如isStatic===true的角色不可以刪除,并且不可以修改名稱;新增用戶和編輯用戶的密碼校驗規(guī)則需要區(qū)別對待;保存權(quán)限是差異保存。等等。。。有條件的可以看一下ABP的Angular代碼。
租戶管理
基本功能界面都差不多。。。但是這里有一個”管理功能“的選項,默認是顯示”沒有可用的功能“:
這玩意在界面上沒地方添加,也沒地方刪除,但是這個功能相當實用。它來自ABP的FeatureManagement模塊,也稱為”特征管理“,這個后面再做介紹。
租戶切換
完成了租戶管理,那么登錄時也應(yīng)該可以切換租戶。
切換租戶比較簡單,就是根據(jù)輸入的租戶名稱獲取到租戶ID,然后調(diào)用/abp/application-configuration接口,把租戶ID放到請求Header的__tenant字段中即可,之后的請求中也需要這個參數(shù),不傳的話就是默認的宿主端。
其實ABP后端是可以配置是否啟用多租戶的,這里也可以根據(jù)后端配置來顯示或者隱藏租戶切換的按鈕。跟ABP模板相比,登錄界面還缺少一個注冊入口,后面再加上吧。
效果
最后
前端部分的模塊開發(fā)就不再詳細介紹了,主題還是ABP。進行到這里,ABP模板自帶的前端部分功能就差不多完成了,需要代碼的可以去 https://github.com/xiajingren/HelloAbp 拉取,后面我再把文件整理一下,弄一個干凈的vue版本。
以上就是詳解vue身份認證管理和租戶管理的詳細內(nèi)容,更多關(guān)于vue身份認證管理和租戶管理的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
關(guān)于Vue的URL轉(zhuǎn)跳與參數(shù)傳遞方式
這篇文章主要介紹了關(guān)于Vue的URL轉(zhuǎn)跳與參數(shù)傳遞方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03iview+vue實現(xiàn)導入EXCEL預(yù)覽功能
這篇文章主要為大家詳細介紹了iview+vue實現(xiàn)導入EXCEL預(yù)覽功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07vue使用localStorage保存登錄信息 適用于移動端、PC端
這篇文章主要為大家詳細介紹了vue使用localStorage保存登錄信息 適用于移動端、PC端,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-05-05Vue3+Canvas實現(xiàn)坦克大戰(zhàn)游戲(一)
這篇文章將利用Vue3和Canvas編寫一個童年經(jīng)典游戲—坦克大戰(zhàn),文中的示例代碼講解詳細,感興趣的小伙伴快來跟隨小編一起學習一下吧2022-03-03Vue??vuex配置項和多組件數(shù)據(jù)共享案例分享
這篇文章主要介紹了Vue??vuex配置項和多組件數(shù)據(jù)共享案例分享,文章圍繞Vue?Vuex的相關(guān)資料展開配置項和多組件數(shù)據(jù)共享的案例分享,需要的小伙伴可以參考一下2022-04-04vue中使用elementUI自定義校驗及點擊提交不生效問題解決辦法
我們在項目中經(jīng)常會用到ElementUI的表單驗證,下面這篇文章主要給大家介紹了關(guān)于vue中使用elementUI自定義校驗及點擊提交不生效問題解決的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2023-12-12