首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  程序员

跨域请求如何携带 cookie

  •  
  •   yantianqi · 244 天前 · 2373 次点击
    这是一个创建于 244 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    5 回复  |  直到 2018-01-19 17:18:18 +08:00
        1
    dilu   244 天前
    一个是用 jsonp 一个是修改 heade 请求 增加个什么东西来着
    还有一个解决办法 使用 nginx 转发 例如将前端的 3000 转发到 80 端口 后端的端口转发到 80 下面的 /api 路径 然后你的前端直接请求 /api 路径即可
        2
    sunzongzheng   244 天前 via Android
        3
    qiuyk   244 天前
    后端创建 session 一般一些关键信息放在 Cookies 里,通过响应的 Set-Cookie 头部中,浏览器会自动保存的。不过一般会设置 httpOnly,js 拿不到的。

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

    对于非 GET 和 POST 请求,浏览器一般会先发一个 OPTION 请求,后端需要响应 200,浏览器才会发送真正的请求。
        4
    jackroyal   244 天前
    前端和后端都需要设置 Credentials, 后端如果是 PHP 的话是设置 header("Access-Control-Allow-Credentials: true");
        5
    sudden   244 天前
    header 中有几个字段要设置,允许指定源
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   720 人在线   最高记录 3762   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.1 · 18ms · UTC 19:18 · PVG 03:18 · LAX 12:18 · JFK 15:18
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1