跨域请求如何携带 cookie

2018-01-19 09:22:59 +08:00
 yantianqi

用的 vue,axios,前后台分离.
跨域过程请求如何携带 cookie
后台设置 session 的时候要把 cookie 存到 Cookies 中是吗?
还是怎么设置
axios 已经设置了 withCredentials = true

6155 次点击
所在节点    程序员
5 条回复
dilu
2018-01-19 09:33:51 +08:00
一个是用 jsonp 一个是修改 heade 请求 增加个什么东西来着
还有一个解决办法 使用 nginx 转发 例如将前端的 3000 转发到 80 端口 后端的端口转发到 80 下面的 /api 路径 然后你的前端直接请求 /api 路径即可
sunzongzheng
2018-01-19 09:33:59 +08:00
qiuyk
2018-01-19 10:37:53 +08:00
后端创建 session 一般一些关键信息放在 Cookies 里,通过响应的 Set-Cookie 头部中,浏览器会自动保存的。不过一般会设置 httpOnly,js 拿不到的。

同时后端响应需要设置 Access-Control 那四个字段,Origin 不能为*,Credentials 为 true,Headers 要有 Cookie。

对于非 GET 和 POST 请求,浏览器一般会先发一个 OPTION 请求,后端需要响应 200,浏览器才会发送真正的请求。
jackroyal
2018-01-19 10:45:40 +08:00
前端和后端都需要设置 Credentials, 后端如果是 PHP 的话是设置 header("Access-Control-Allow-Credentials: true");
sudden
2018-01-19 17:18:18 +08:00
header 中有几个字段要设置,允许指定源

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/424111

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX