vue.js - laravel axios跨域请求的cookie问题
本文介绍了vue.js - laravel axios跨域请求的cookie问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
在Laravel下创建了子域名路由api.service.dev,认证我是用的passport
,启用了CreateFreshApiToken
。
service.dev这个域名下可以正常获取laravel_token,并请求但是请求https://api.service.dev/user
时提示401 Unauthenticated。
查看请求头中没有携带CreateFreshApiToken创建的laravel_token
这个cookie
请问大神怎么解决?
解决方案
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了!!!
这篇关于vue.js - laravel axios跨域请求的cookie问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文