在Laravel下创建了子域名路由api.service.dev,认证我是用的passport,启用了CreateFreshApiToken。
passport
CreateFreshApiToken
service.dev这个域名下可以正常获取laravel_token,并请求但是请求https://api.service.dev/user 时提示401 Unauthenticated。
https://api.service.dev/user
查看请求头中没有携带CreateFreshApiToken创建的laravel_token 这个cookie
laravel_token
请问大神怎么解决?
安装方法请移步https://github.com/barryvdh/l...
return [ /* |-------------------------------------------------------------------------- | Laravel CORS |-------------------------------------------------------------------------- | | allowedOrigins, allowedHeaders and allowedMethods can be set to array('*') | to accept any value. | */ 'supportsCredentials' => true, 'allowedOrigins' => ['*'], 'allowedHeaders' => ['*'], 'allowedMethods' => ['*'], 'exposedHeaders' => [], 'maxAge' => 0, ];
在.env文件中添加SESSION_DOMAIN=.xxx.com,我这里是service.dev,所以应该填写.service.dev,这样所有service.dev的子域名都能共享Cookie
SESSION_DOMAIN=.xxx.com
在bootstrap.js中加入如下代码
bootstrap.js
window.axios.defaults.withCredentials = true;
这样就能正常访问跨域api了!!!
axios配置了withCredentials = true后在chrome下没问题。但IE下还需要服务器端配置P3P的响应头。。。IE就是这么有个性
1、安装barryvdh/laravel-cors
安装方法请移步https://github.com/barryvdh/l...
2、配置cors.php
3、配置session的domain
在.env文件中添加
SESSION_DOMAIN=.xxx.com
,我这里是service.dev,所以应该填写.service.dev,这样所有service.dev的子域名都能共享Cookie4、最后配置前端的请求
在
bootstrap.js
中加入如下代码这样就能正常访问跨域api了!!!
axios配置了withCredentials = true后在chrome下没问题。
但IE下还需要服务器端配置P3P的响应头。。。IE就是这么有个性