Yii2實現多域名跨域同步登錄退出
更新時間:2017年02月04日 10:40:00 作者:lmjy102
本篇文章主要介紹了Yii2實現多域名跨域同步登錄退出,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
在平臺開發(fā)過程中,項目分為前臺(frontend)www.xxx.com和后臺(backend) yun.xxx.com兩部分,綁定兩個域名, 我們知道在沒有綁定域名的時候前后臺可以同步登錄和退出,但是綁定域名后就失效了,原因是session的作用域不同了。 兩個域名的session作用域都只限制在了自己的域名上,我們的解決辦法是將不同二級域名的作用域都改成頂級域名xxx.com。
在common/config/main.PHP里面增加如下代碼:
//跨域session域名配置,獲取當前主機名
$host_array = explode('.', $_SERVER["HTTP_HOST"]);
//針對com域名,獲取頂級域名
if (count($host_array) == 3) {
define('DOMAIN', $host_array[1] . '.' . $host_array[2]);
}
//針對com.cn域名
elseif (count($host_array) == 4) {
define('DOMAIN', $host_array[1] . '.' . $host_array[2]. '.' . $host_array[3]);
}
else{
//echo "本系統(tǒng)不支持本地訪問,請配置域名";exit;
}
define('DOMAIN_HOME', 'www.' . DOMAIN);
define('DOMAIN_YUN', 'yun.' . DOMAIN);
define('DOMAIN_API', 'api.' . DOMAIN);
define('DOMAIN_EMAIL', 'mail.' . DOMAIN);
define('DOMAIN_IMG', 'img.' . DOMAIN);
修改components部分,改變session作用域
'user' => [
'identityClass' => 'common\models\User',
'enableAutoLogin' => true,
'identityCookie' => ['name' => '_identity', 'httpOnly' => true, 'domain' => '.' . DOMAIN],
],
'session' => [
'cookieParams' => ['domain' => '.' . DOMAIN, 'lifetime' => 0],
'timeout' => 3600,
],
通過上述配置后,多個二級域名間就可以實現同步登錄和退出了。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
php array_reverse 以相反的順序返回數組實例代碼
本篇文章主要介紹了php array_reverse 以相反的順序返回數組實例代碼,具有一定的參考價值,有興趣的可以了解一下。2017-04-04
詳解php中serialize()和unserialize()函數
這篇文章主要介紹了php的serialize()函數和unserialize()函數的相關資料,需要的朋友可以參考下2017-07-07

