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

Vue Element前端應(yīng)用開發(fā)之整合ABP框架的前端登錄

 更新時間:2021年05月13日 09:58:56   作者:伍華聰  
VUE+Element 前端是一個純粹的前端處理,前面介紹了很多都是Vue+Element開發(fā)的基礎(chǔ),從本章隨筆開始,就需要進入深水區(qū)了,需要結(jié)合ABP框架使用

概述

ABP框架作為后端,是一個非常不錯的技術(shù)方向,但是前端再使用Asp.NET 進行開發(fā)的話,雖然會快捷一點,不過可能顯得有點累贅了,因此BS的前端選項采用Vue+Element來做管理(后續(xù)可能會視情況加入Vue+AntDesign),CS前端我已經(jīng)完成了使用Winform+ABP的模式了。本篇隨筆主要介紹Vue+Element+ABP的整合方式,先從登錄開始介紹。

1、ABP開發(fā)框架的回顧

ABP是ASP.NET Boilerplate的簡稱,ABP是一個開源且文檔友好的應(yīng)用程序框架。ABP不僅僅是一個框架,它還提供了一個最徍實踐的基于領(lǐng)域驅(qū)動設(shè)計(DDD)的體系結(jié)構(gòu)模型。

啟動Host的項目,我們可以看到Swagger的管理界面如下所示。

我們登錄獲得用戶訪問令牌token后,測試字典類型或者字典數(shù)據(jù)的接口,才能返回響應(yīng)的數(shù)據(jù)。

我根據(jù)ABP后端項目之間的關(guān)系,整理了一個架構(gòu)的圖形。

應(yīng)用服務(wù)層是整個ABP框架的靈魂所在,對內(nèi)協(xié)同倉儲對象實現(xiàn)數(shù)據(jù)的處理,對外配合Web.Core、Web.Host項目提供Web API的服務(wù),而Web.Core、Web.Host項目幾乎不需要進行修改,因此應(yīng)用服務(wù)層就是一個非常關(guān)鍵的部分,需要考慮對用戶登錄的驗證、接口權(quán)限的認(rèn)證、以及對審計日志的記錄處理,以及異常的跟蹤和傳遞,基本上應(yīng)用服務(wù)層就是一個大內(nèi)總管的角色,重要性不言而喻。

對于通過Winform方式展示界面,以Web API方式和后端的ABP的Web API服務(wù)進行數(shù)據(jù)交互,是我們之前已經(jīng)完成的項目,項目界面如下所示。

主體框架界面采用的是基于菜單的動態(tài)生成,以及多文檔的界面布局,具有非常好的美觀性和易用性。

左側(cè)的功能樹列表和頂部的菜單模塊,可以根據(jù)角色擁有的權(quán)限進行動態(tài)構(gòu)建,不同的角色具有不同的菜單功能點,如下是測試用戶登錄后具有的界面。

2、Vue+Element整合ABP框架的前端登錄處理

之前我們開發(fā)完成的Vue+Element的前端項目,默認(rèn)已經(jīng)具有登錄系統(tǒng)的功能,不過登錄是采用mock方式進行驗證并處理的,本篇隨筆介紹是基于實際的ABP項目進行用戶身份的登錄處理,這個也是開發(fā)其他接口展示數(shù)據(jù)的開始步驟,必須通過真實的用戶身份登錄后臺,獲得對應(yīng)的token令牌,才能進行下一步接口的開發(fā)工作。

例如對應(yīng)登錄界面上,界面效果如下所示。

在用戶登錄界面中,我們處理用戶登錄邏輯代碼如下所示。

// 處理登錄事件
    handleLogin() {
      this.$refs.loginForm.validate(valid => {
        if (valid) {
          this.loading = true
          this.$store
            .dispatch('user/login', this.loginForm)
            .then(() => {
              this.$router.push({ path: this.redirect || '/' })
              this.loading = false
            })
            .catch(() => {
              this.loading = false
            })
        } else {
          console.log('error submit!!')
          return false
        }
      })
    }

這里主要就是調(diào)用Store模塊里面的用戶Action處理操作。

例如對于用戶store模塊里面的登錄Action函數(shù)如下所示。

const actions = {
  // user login
  login({ commit }, userInfo) {
    const { username, password } = userInfo
    return new Promise((resolve, reject) => {
      login({ username: username.trim(), password: password }).then(response => {
        const { result } = response // 獲取返回對象的 result
        var token = result.accessToken
        var userId = result.userId

        // 記錄令牌和用戶Id
        commit('SET_TOKEN', token)
        commit('SET_USERID', userId)

        // 存儲cookie
        setToken(token)
        setUserId(userId)
        resolve()
      }).catch(error => {
        reject(error)
      })
    })
  },

而其中l(wèi)ogin({ username: username.trim(), password: password }) 操作,是通過API封裝處理的調(diào)用,使用前在Store模塊中先引入API模塊,如下所示。

import { login, logout, getInfo } from '@/api/user'

而其中 API模塊代碼如下所示。

export function login(data) {
  return request({
    url: '/abp/TokenAuth/Authenticate',
    method: 'post',
    data: {
      UsernameOrEmailAddress: data.username,
      password: data.password
    }
  })
}

這里我們用了一個/abp的前綴,用來給WebProxy的處理,實現(xiàn)地址的轉(zhuǎn)義,從而可以實現(xiàn)跨站的處理,讓前端調(diào)用外部地址就和調(diào)用本地地址一樣,無縫對接。

我們來看看vue.config.js里面對于這個代理的轉(zhuǎn)義操作代碼。

而http://localhost:21021/api 地址指向的項目,是我們本地使用ABP開發(fā)的一個后端Web API項目,我們可以通過地址http://localhost:21021/swagger/index.html進行接口的查看。

我們打開獲取授權(quán)令牌的Authenticate接口,查看它的接口定義內(nèi)容

通過標(biāo)注的1,2,我們可以看到這個接口的輸入?yún)?shù)和輸出JSON信息,從而為我們封裝Web API的調(diào)用提供很好的參考。

ABP框架統(tǒng)一返回的結(jié)果是result,這個result里面才是返回對應(yīng)的接口內(nèi)容,如上面的輸出JSON信息里面的定義。

所以在登陸返回結(jié)果后,我們要返回它的result對象,然后在進行數(shù)據(jù)的處理。

const { result } = response // 獲取返回對象的 result

然后通過result來訪問其他屬性即可。

var token = result.accessToken // 用戶令牌
var userId = result.userId // 用戶id

用戶登錄成功后,并獲取到對應(yīng)的數(shù)據(jù),我們就可以把必要的數(shù)據(jù),如token和userid存儲在State和Cookie里面了。

// 修改State對象,記錄令牌和用戶Id
commit('SET_TOKEN', token)
commit('SET_USERID', userId)

// 存儲cookie
setToken(token)
setUserId(userId)

有了這些信息,我們就可以進一步獲取用戶的相關(guān)信息,如用戶名稱、介紹,包含角色列表和權(quán)限列表等內(nèi)容了。

例如對應(yīng)用戶信息獲取接口的ABP后端地址是 http://localhost:21021//api/services/app/User/Get

那么我們前端就需要在API模塊里面構(gòu)建它的訪問地址(/abp/services/app/User/Get)和接口處理了。

export function getInfo(id) {
  return request({
    url: '/abp/services/app/User/Get',
    method: 'get',
    params: {
      id
    }
  })
}

如上所示,在Store模塊里引入API模塊,如下所示。

import { login, logout, getInfo } from '@/api/user'

然后在Store模塊中封裝一個Action用來處理用戶信息的獲取的。

// 獲取用戶信息
  getInfo({ commit, state }) {
    return new Promise((resolve, reject) => {
      getInfo(state.userid).then(response => {
        const { result } = response
        console.log(result) // 輸出測試

        if (!result) {
          reject('Verification failed, please Login again.')
        }

        const { roles, roleNames, name, fullName } = result

        // 角色非空提醒處理
        if (!roles || roles.length <= 0) {
          reject('getInfo: roles must be a non-null array!')
        }

        commit('SET_ROLES', { roles, roleNames })
        commit('SET_NAME', name)
        // commit('SET_AVATAR', avatar) //可以動態(tài)設(shè)置頭像
        commit('SET_INTRODUCTION', fullName)
        resolve(result)
      }).catch(error => {
        reject(error)
      })
    })
  },

Vue + Element前端項目的視圖、Store模塊、API模塊、Web API之間關(guān)系如下所示。

登錄后我們獲取用戶身份信息,在控制臺中記錄返回對象信息,可以供參考,如下所示

有了token信息,我們就可以繼續(xù)其他接口的數(shù)據(jù)請求或者提交了,從而可以實現(xiàn)更多的管理功能了。

以上就是Vue Element前端應(yīng)用開發(fā)之整合ABP框架的前端登錄的詳細內(nèi)容,更多關(guān)于Vue Element的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue3:vue2中protoType更改為config.globalProperties問題

    vue3:vue2中protoType更改為config.globalProperties問題

    這篇文章主要介紹了vue3:vue2中protoType更改為config.globalProperties問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue混入與插件的使用介紹

    Vue混入與插件的使用介紹

    這篇文章主要介紹了Vue混入與插件的使用,mixins(混入),官方的描述是一種分發(fā) Vue 組件中可復(fù)用功能的非常靈活的方式,mixins是一個js對象,它可以包含我們組件中script項中的任意功能選項,如data、components、methods 、created、computed等等
    2022-09-09
  • Vue2中實現(xiàn)dialog的封裝方式

    Vue2中實現(xiàn)dialog的封裝方式

    這篇文章主要介紹了Vue2中實現(xiàn)dialog的封裝方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Vue3中使用Pinia的方法詳細介紹

    Vue3中使用Pinia的方法詳細介紹

    這篇文章主要給大家介紹了關(guān)于Vue3中使用Pinia的相關(guān)資料,pinia是一個用于vue的狀態(tài)管理庫,類似于vuex,是vue的另一種狀態(tài)管理工具,文中介紹的非常詳細,需要的朋友可以參考下
    2024-01-01
  • 在原生HTML中使用VUE的保姆級教學(xué)

    在原生HTML中使用VUE的保姆級教學(xué)

    Vue.js是一種流行的JavaScript框架,用于構(gòu)建交互式的Web應(yīng)用程序,這篇文章主要給大家介紹了關(guān)于在原生HTML中使用VUE的保姆級教學(xué),需要的朋友可以參考下
    2023-10-10
  • vue debug 二種方法

    vue debug 二種方法

    這篇文章主要介紹了vue debug 二種方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • 關(guān)于Vue腳手架中render 理解

    關(guān)于Vue腳手架中render 理解

    這篇文章主要介紹了Vue腳手架中的 render 理解,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10
  • element ui table(表格)實現(xiàn)點擊一行展開功能

    element ui table(表格)實現(xiàn)點擊一行展開功能

    這篇文章主要給大家介紹了關(guān)于element ui table(表格)實現(xiàn)點擊一行展開功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • vue組件historyApiFallback作用詳解

    vue組件historyApiFallback作用詳解

    這篇文章主要為大家介紹了vue組件historyApiFallback作用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • 在 vue-cli v3.0 中使用 SCSS/SASS的方法

    在 vue-cli v3.0 中使用 SCSS/SASS的方法

    關(guān)于如何在 vue-cli v3.0 中使用 SCSS/SASS,這里提供三種方案。感興趣的朋友通過本文一起學(xué)習(xí)吧
    2018-06-06

最新評論