解决vue项目axios每次请求session不一致的问题


Posted in Javascript onOctober 24, 2020

1、vue开发后台管理项目,登录后,请求数据每次session都不一致,后台返回未登录,处理方法打开main.js设置:

// 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的一致性需设置为true;

2、为解决跨域,需要代理

解决vue项目axios每次请求session不一致的问题

3、数据请求

解决vue项目axios每次请求session不一致的问题

补充知识:解决跨域造成Vue-element每次请求sessionID不同问题

vue-element作为前端开发框架, 前后端分离项目ajax跨域, 每次http请求后sessionId均会发生变化,导致获取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不一致的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
比较详细的关于javascript中void(0)的具体含义解释
Aug 02 Javascript
获取焦点时,利用js定时器设定时间执行动作
Apr 02 Javascript
基于Jquery的回车成tab焦点切换效果代码(Enter To Tab )
Nov 14 Javascript
JS实现超炫网页烟花动画效果的方法
Mar 02 Javascript
dul无法加载bootstrap实现unload table/user恢复
Sep 29 Javascript
JS实现微信弹出搜索框 多条件查询功能
Dec 13 Javascript
基于jQuery实现数字滚动效果
Jan 16 Javascript
jquery+ajax实现省市区三级联动 (封装和不封装两种方式)
May 15 jQuery
React-Native使用Mobx实现购物车功能
Sep 14 Javascript
Vue 引入AMap高德地图的实现代码
Apr 29 Javascript
layui的面包屑或者表单不显示的解决方法
Sep 05 Javascript
vue配置nprogress实现页面顶部进度条
Sep 21 Javascript
解决vue中使用less/sass及使用中遇到无效的问题
Oct 24 #Javascript
vue中是怎样监听数组变化的
Oct 24 #Javascript
JSON stringify方法原理及实例解析
Oct 23 #Javascript
vue中使用腾讯云Im的示例
Oct 23 #Javascript
vue中使用router全局守卫实现页面拦截的示例
Oct 23 #Javascript
vue使用video插件vue-video-player详解
Oct 23 #Javascript
vue-video-player视频播放器使用配置详解
Oct 23 #Javascript
You might like
JAVA/JSP学习系列之七
2006/10/09 PHP
定制404错误页面,并发信给管理员的程序
2006/10/09 PHP
?算你??的 PHP 程式大小
2006/12/06 PHP
生成静态页面的php函数,php爱好者站推荐
2007/03/19 PHP
基于PHP遍历数组的方法汇总分析
2013/06/08 PHP
php查看请求头信息获取远程图片大小的方法分享
2013/12/25 PHP
php顺序查找和二分查找示例
2014/03/27 PHP
JS高级调试技巧:捕获和分析 JavaScript Error详解
2014/03/16 Javascript
编写自己的jQuery提示框(Tip)插件
2015/02/05 Javascript
jQuery中使用each处理json数据
2015/04/23 Javascript
jQuery学习笔记之回调函数
2016/08/15 Javascript
JS小数转换为整数的方法分析
2017/01/07 Javascript
获取url中用&amp;隔开的参数实例(分享)
2017/05/28 Javascript
angularJs使用$watch和$filter过滤器制作搜索筛选实例
2017/06/01 Javascript
Vue2.0用 watch 观察 prop 变化(不触发)
2017/09/08 Javascript
详解webpack2+React 实例demo
2017/09/11 Javascript
详解Nodejs mongoose
2018/06/10 NodeJs
基于Vue+element-ui 的Table二次封装的实现
2018/07/20 Javascript
了解javascript中let和var及const关键字的区别
2019/05/24 Javascript
Vue实现数据表格合并列rowspan效果
2020/11/30 Javascript
Python中用Descriptor实现类级属性(Property)详解
2014/09/18 Python
Python使用flask框架操作sqlite3的两种方式
2018/01/31 Python
Pyqt助手安装PyQt5帮助文档过程图解
2020/11/20 Python
使用OpenCV实现人脸图像卡通化的示例代码
2021/01/15 Python
html5视频播放_动力节点Java学院整理
2017/07/13 HTML / CSS
阿玛尼化妆品美国官网:Giorgio Armani Beauty
2017/02/02 全球购物
乌克兰电子和家用电器商店:Foxtrot
2019/07/23 全球购物
校本教研工作制度
2014/01/22 职场文书
抽奖活动主持词
2014/03/31 职场文书
护士上岗前培训自我鉴定
2014/04/20 职场文书
法人委托书
2014/07/31 职场文书
学生会副主席竞选稿
2015/11/19 职场文书
Python编写nmap扫描工具
2021/07/21 Python
golang实现一个简单的websocket聊天室功能
2021/10/05 Golang
Windows下载并安装MySQL8.0.x 版本的完整教程
2022/04/10 MySQL
MSSQL基本语法操作
2022/04/11 SQL Server