您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關(guān)vue項目中axios每次請求session不一致怎么解決,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
1、vue開發(fā)后臺管理項目,登錄后,請求數(shù)據(jù)每次session都不一致,后臺返回未登錄,處理方法打開main.js設(shè)置:
// The Vue build version to load with the `import` command // (runtime-only or standalone) has been set in webpack.base.conf with an alias. import Vue from 'vue' import App from './App' import router from './router' require('es6-promise').polyfill() import MintUI from 'mint-ui' import 'mint-ui/lib/style.css' import ElementUI from 'element-ui'; import 'element-ui/lib/theme-chalk/index.css'; import store from './store' import axios from 'axios' // 1、在這里引入axios axios.interceptors.response.use(function(res) { var res = res.data; if(res.status === 403 ) { router.push('/') return res; } return res; }, function(error) { return Promise.reject(error); }); axios.defaults.withCredentials = true; //意思是攜帶cookie信息,保持session的一致性 Vue.prototype.$axios = axios Vue.prototype.stringify = require('qs').stringify; Vue.use(MintUI) Vue.use(ElementUI); Vue.config.productionTip = false /* eslint-disable no-new */ new Vue({ el: '#app', router, store, components: { App }, template: '<App/>' })
withCredentials為false意思是不攜帶cookie信息,為保持session的一致性需設(shè)置為true;
2、為解決跨域,需要代理
3、數(shù)據(jù)請求
補充知識:解決跨域造成Vue-element每次請求sessionID不同問題
vue-element作為前端開發(fā)框架, 前后端分離項目ajax跨域, 每次http請求后sessionId均會發(fā)生變化,導(dǎo)致獲取session失敗,
只需要在文件vue-element-admin-master-1\src\utils\request.js中添加如下代碼即可:
withCredentials: true,
crossDomain: true
整個axios請求為:
const service = axios.create({ baseURL: process.env.BASE_API, // api的base_url timeout: 5000, // request timeout withCredentials: true, crossDomain: true })
以上就是vue項目中axios每次請求session不一致怎么解決,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。