您的位置:首页 > Web前端 > Vue.js

vue解决服务器Session不一致问题(跨域问题)

2021-05-02 19:11 519 查看

       最近在做项目时,发现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
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: