亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Vue+Express實現登錄注銷功能的實例代碼

2019-11-19 11:39:09
字體:
來源:轉載
供稿:網友
  • 對Vue全家桶有基本的認知.
  • 用有node環境
  • 了解express

一丶業務分析

1.什么情況下進行權限驗證?

訪問敏感接口

  • 前端向后端敏感接口發送ajax
  • 后端進行session驗證,并返回信息
  • 前端axios攔截返回信息,根據返回信息進行操作

進行頁面切換

  • 頁面切換,觸發vue-router的路由守衛
  • 路由守衛根據跳轉地址進行驗證,如需權限,則發送ajax至后端驗證接口
  • 后端驗證接口進行session驗證,返回信息
  • 前端根據后端返回信息進行操作

2.前后端進行了怎么的交互?

登錄

注銷

二丶項目環境

基礎環境( 有興趣自己動手做一遍這個登錄注冊的,可進入github克隆基礎環境 )

  • Vue(前端):vue vuex(存儲狀態) axios(發送,攔截ajax信息) vue-router(單頁面路由)
  • Express(后端): express(后端服務器環境)

正式開發依賴

  • express-session(express中間件,用于生成session)

三丶項目開始前

1.創建項目目錄,配置路由,創建頁面跳轉組件

項目目錄:

創建components/route_list.vue進行頁面跳轉

<template>  <div>   <p><router-link :to="{name:'index'}">主頁</router-link></p>   <p><router-link :to="{name:'login'}">登錄</router-link></p>   <p><router-link :to="{name:'logout'}">注銷</router-link></p>   <p><router-link :to="{name:'me'}">個人信息</router-link></p>   <p>登錄狀態:{{this.$store.state.me.login}}</p>  </div> </template>

創建stores/me.js倉庫,存放登錄狀態

import Vue from 'vue'import router from '../router';export default{  namespaced:true,  state:{    login :false  },  mutations:{    changeLogin(state,{result}){       state.login = result;    }  },  actions:{    async checkMe({commit}){      const result = await Vue.prototype.$http.get('/me').then(data=>data.data);      if(!result){        router.push({name:'login'})        return      }      commit('changeLogin',{result})    }  }}

views中 新建Login,Logout,Signin,me組件

路由信息寫在router.js中

2.配置路由: 引入各個頁面,進行路由跳轉配置

后端配置express-session

//serve/app.js文件 express服務器 const express = require('express')//中間件--用于下發sessionconst session = require('express-session')const app = express()//使用express-session下發sessionapp.set('trust proxy', 1)app.use(session({ secret: 'keyboard cat', resave: false, saveUninitialized: true,}))

四丶權限驗證 - 敏感接口

1.主頁Index.vue--訪問敏感接口,展示敏感接口數據

<template>  <div>    //請求后臺數據    <Button @click="getTest">敏感接口</Button>    //請求信息展示    {{result}}    //頁面跳轉組件   <route_list></route_list>  </div></template><script>import route_list from '../components/route_list'  export default {    components:{      route_list    },    data(){      return{        result:""      }    },    methods:{    //請求敏感接口     async getTest(){       this.result = await this.$http.get("/").then(res=>res.data)     }    }  }</script>

2.后端的敏感接口接收到請求,進行判斷

app.get('/', function (req, res) { if(req.session.login){  res.send("hello world") }else{ res.send(403) }})

3.axios--發送ajax后,對后端返回數據進行攔截,判斷

import axios from 'axios';import url from 'url';import router from '../src/router'//創建axios實例var instance = axios.create({  baseURL: '/api'});//攔截器 instance.interceptors.response.use(  function(response){    return response;  },function(error){    //敏感接口.如果沒有session跳轉登錄界面    if(error.response.status==403){      router.push({name:"login"})    }  }) export default instance;

如果返回結果為true,登錄狀態,就可以進行訪問敏感接口了.

五丶權限驗證 - 頁面跳轉

1.路由守衛,對跳轉頁面進行監視

//路由守衛  router.beforeEach((to,from,next)=>{ if(to.name != 'login' && to.name != 'index'){  store.dispatch('me/checkMe') }  next()})

2.store中checkme,當跳轉敏感頁面時進行驗證

actions:{    async checkMe({commit}){      //請求/me接口,對登錄信息進行判斷,并保留狀態      const result = await Vue.prototype.$http.get('/me').then(data=>data.data);      //返回值為false,跳轉至login      if(!result){        router.push({name:'login'})        return      }      commit('changeLogin',{result})    }  }

3.后端的檢測登錄接口接收到請求,進行判斷

//驗證是否登錄app.get('/me', function (req, res) { //判斷session是否為true if(req.session.login){  res.send(true) }else{  res.send(false) }})

如果返回結果為true,登錄狀態,就可以進行頁面跳轉了.

六丶登錄

1.登錄頁Login.vue - 請求登錄接口,登錄成功后將信息保存到store

<template>  <div><h1>登錄</h1><Button @click="login">登錄</Button><route_list></route_list>  </div></template><script>import route_list from '../components/route_list'  export default {    components:{      route_list    },   methods:{     async login(){     //請求登錄接口      const result = await this.$http.get("/login").then(data=>data.data);      //記錄登錄狀態      this.$store.commit('me/changeLogin',{result})     }    },}</script>

2.后端登錄接口接收到請求,生成session

//登錄接口,更改session狀態app.get('/login', function (req, res) {  req.session.login = true, res.send(true)})

現在就是登錄狀態了

七丶注銷

1.登錄頁Logout.vue - 請求注銷接口,注銷成功后將信息保存到store

<template>  <div>    <h1>注銷</h1><Button @click="login">注銷</Button><route_list></route_list>  </div></template><script>import route_list from '../components/route_list'  export default {    components:{      route_list    },  data(){    return{          }  },   methods:{     async login(){      const result = await this.$http.get("/logout").then(data=>data.data);      this.$store.commit('me/changeLogin',{result})     }    },    }</script>

2.后端注銷接口接收到請求,更改session狀態

//登錄接口,更改session狀態app.get('/login', function (req, res) {  req.session.login = false, res.send(false)})

現在就是注銷狀態了

總結

以上所述是小編給大家介紹的Vue+Express實現登錄注銷功能的實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产香蕉一区二区三区在线视频| 国产一区二区在线播放| 国内精品400部情侣激情| 97色伦亚洲国产| 欧美日本中文字幕| 国产欧美va欧美va香蕉在线| 日韩国产精品视频| 亲爱的老师9免费观看全集电视剧| 国产在线观看精品| 国产午夜精品视频| 久久久av免费| 亚洲国产精品久久久久秋霞不卡| 国产精品国语对白| 91久久久久久久久久| 国产精品一区电影| 日本午夜在线亚洲.国产| 黑人巨大精品欧美一区二区| 欧美精品少妇videofree| 国产欧亚日韩视频| 国产精品极品尤物在线观看| 欧美日韩福利在线观看| 国产精品偷伦视频免费观看国产| 怡红院精品视频| 日韩av在线一区| 91丝袜美腿美女视频网站| 久久久亚洲影院| 欧美大片在线看免费观看| 色妞欧美日韩在线| 亚洲午夜国产成人av电影男同| 欧美富婆性猛交| 亚洲人免费视频| 久久久亚洲天堂| 成人精品一区二区三区电影黑人| 欧美一级淫片播放口| 国产精彩精品视频| 亚洲日本中文字幕| 97人洗澡人人免费公开视频碰碰碰| 国产一区深夜福利| 久久精品99国产精品酒店日本| 欧美日韩国产综合新一区| 欧美国产视频日韩| 成人久久18免费网站图片| 日韩成人在线视频观看| 国产做受高潮69| 91av成人在线| 成人午夜黄色影院| 欧美小视频在线| 91精品国产高清久久久久久久久| 欧美二区乱c黑人| 欧美黑人性生活视频| 国产99久久久欧美黑人| 亚洲男人天堂2019| 日韩欧美国产中文字幕| 久久久久久久网站| 国产精品第3页| 欧美天天综合色影久久精品| 国产成人精品视频在线| 日产日韩在线亚洲欧美| 久久综合免费视频| 日韩精品欧美激情| 欧美一级淫片丝袜脚交| 欧美日韩日本国产| 精品亚洲一区二区| 国产精品成人一区二区三区吃奶| 中文字幕久久久av一区| 国产一区二区三区在线观看网站| 亚洲精品电影网在线观看| 日韩成人黄色av| 久久久精品国产| 亚洲伊人久久综合| 亚洲欧美在线一区二区| 欧美福利小视频| 久久精品国产欧美亚洲人人爽| 久久亚洲私人国产精品va| 欧美在线观看网址综合| 日韩av电影在线免费播放| 在线视频亚洲欧美| 久久人体大胆视频| 亚洲福利小视频| 一本色道久久综合狠狠躁篇的优点| 久久久久国产精品免费| 亚洲成人久久久| 日韩精品中文字幕有码专区| 精品国产老师黑色丝袜高跟鞋| 久久国产精品久久久久久| 久久91亚洲精品中文字幕奶水| 国产视频丨精品|在线观看| 日韩精品免费观看| 一本色道久久88亚洲综合88| 色与欲影视天天看综合网| 亚洲欧美在线免费| 久久久伊人欧美| 亚洲日韩中文字幕| 国产suv精品一区二区| 欧美精品18videos性欧| 欧美国产精品va在线观看| 日韩成人在线视频网站| 亚洲女性裸体视频| 亚洲网站在线播放| 国产ts一区二区| 色综合老司机第九色激情| 国产精品视频网| 欧美福利视频在线| 97视频在线观看亚洲| 欧美成人免费小视频| zzjj国产精品一区二区| 中文字幕综合一区| 国产综合在线看| 91伊人影院在线播放| 一区二区欧美激情| 国产在线一区二区三区| 91精品国产综合久久久久久久久| 日韩一区二区在线视频| 国产一区二区黑人欧美xxxx| 久久久久久久成人| 国产一区二区三区欧美| 4k岛国日韩精品**专区| 成人精品视频99在线观看免费| 中文字幕亚洲欧美| 欧美xxxx14xxxxx性爽| 国产成人鲁鲁免费视频a| 久久久久久成人精品| 日韩成人在线免费观看| 日韩在线国产精品| 久久久久久久久久久国产| 97视频在线观看视频免费视频| 最近2019中文字幕在线高清| 欧洲成人免费视频| 91国自产精品中文字幕亚洲| 亚洲精品免费av| 日韩视频免费在线| 4k岛国日韩精品**专区| …久久精品99久久香蕉国产| 欧美亚洲视频在线看网址| 国产成人高潮免费观看精品| 97色在线视频观看| 亚洲天堂网站在线观看视频| 91成人福利在线| 亚洲福利视频免费观看| 精品久久久久久中文字幕一区奶水| 日韩在线观看网址| 亚洲欧美制服第一页| 亚洲tv在线观看| 国产精品露脸av在线| 亚洲图片欧洲图片av| 亚洲自拍av在线| 亚洲第一区中文字幕| 亚洲午夜精品久久久久久性色| 亚洲成人久久久| 欧美体内谢she精2性欧美| 96国产粉嫩美女| 91探花福利精品国产自产在线| 亚洲天堂免费观看| 91色琪琪电影亚洲精品久久| 欧美高清理论片| 中文字幕在线视频日韩| 欧美刺激性大交免费视频| 国产精品欧美风情| 国产精品嫩草影院一区二区| 日韩精品高清在线| 国产成人精品综合久久久| 狠狠躁夜夜躁人人爽超碰91| 亚洲自拍偷拍网址| 91久久精品一区|