在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就是這麼有個性