vue解决服务器Session不一致问题(跨域问题)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了vue解决服务器Session不一致问题(跨域问题),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1372字,纯文字阅读大概需要2分钟。
内容图文
![vue解决服务器Session不一致问题(跨域问题)](/upload/InfoBanner/zyjiaocheng/993/8163b137fb1947ad895e13a873ee752b.jpg)
最近在做项目时,发现vue前端的登录接口使用axios连接服务器实现登录功能时,每次请求后端服务器所保存的Session对象id都不相同,也就是说前端请求服务器所得到的Seesion对象无法保存下来。
上网查询后发现是跨域问题,也就是说请求的发出点的URL与所请求的URL不同源。(所谓同源(即指在同一个域)就是两个页面具有相同的协议(protocol),主机(host)和端口号(port))。
那么如何解决跨域问题呢,目前网络上主要有两种解决方案:
1.允许使用cookie,携带session信息,保持session的一致性。(大概率无法解决问题)
在vue项目中的main.js中添加(前提是以引用axios):
axios.defaults.withcredentials = true; //允许使用cookie
在后端代码中同样允许使用cookie(以SpringMVC为例)
//作为Controller类的注解
@CrossOrigin(origins ="http://localhost:8081",allowCredentials = "true") //允许跨域,同时允许使用cookie
2.使用 vue proxy 代理——将不同源的URL通过代理更改为同源(大概率能解决问题)
以vue-cli3为例,在vue项目根目录下创建配置文件vue.config.js(与package.json同级),在配置文件中添加以下代码:
module.exports = {
//相当于webpack-dev-server, 对本地服务器进行配置
devServer : {
proxy: {
//以“/a”作为开头的axios请求都会进行代理
"/a" : {
target: "http://localhost:8080", //请求目标服务器的url
changeOrigin: true, //是否跨域(选为true)
pathRewrite: {
"^/a" : "" //将axios请求url中的/a进行重写
}
}
}
}
//通过以上配置,对于axios请求:/a/login 将会被代理成 http://localhost:8080/login
}
内容总结
以上是互联网集市为您收集整理的vue解决服务器Session不一致问题(跨域问题)全部内容,希望文章能够帮你解决vue解决服务器Session不一致问题(跨域问题)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。