vue.js - laravel axios跨域请求的cookie问题
仅有的幸福
仅有的幸福 2017-05-16 16:47:15
[PHP讨论组]

在Laravel下创建了子域名路由api.service.dev,认证我是用的passport,启用了CreateFreshApiToken

service.dev这个域名下可以正常获取laravel_token,并请求但是请求https://api.service.dev/user 时提示401 Unauthenticated。

查看请求头中没有携带CreateFreshApiToken创建的laravel_token 这个cookie

请问大神怎么解决?

仅有的幸福
仅有的幸福

全部回复(2)
世界只因有你

1、安装barryvdh/laravel-cors

安装方法请移步https://github.com/barryvdh/l...

2、配置cors.php

return [
    /*
     |--------------------------------------------------------------------------
     | Laravel CORS
     |--------------------------------------------------------------------------
     |
     | allowedOrigins, allowedHeaders and allowedMethods can be set to array('*')
     | to accept any value.
     |
     */
    'supportsCredentials' => true,
    'allowedOrigins' => ['*'],
    'allowedHeaders' => ['*'],
    'allowedMethods' => ['*'],
    'exposedHeaders' => [],
    'maxAge' => 0,
];

3、配置session的domain

在.env文件中添加SESSION_DOMAIN=.xxx.com,我这里是service.dev,所以应该填写.service.dev,这样所有service.dev的子域名都能共享Cookie

4、最后配置前端的请求

bootstrap.js中加入如下代码

window.axios.defaults.withCredentials = true;

这样就能正常访问跨域api了!!!

过去多啦不再A梦

axios配置了withCredentials = true后在chrome下没问题。
但IE下还需要服务器端配置P3P的响应头。。。IE就是这么有个性

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号