您的位置:首页 > 其它

wordpress二次开发教程手记:站点用户数据共享后的登录问题

2013-07-04 16:07 731 查看
在上一个教程中小V实现了wordpress的多个站点站点的用户数据共享,但是用户在登录站点1后继续访问站点2时仍需要重新登录,这样对于用户体验的非常不好的,但是目前没有什么很好的解决方法,不过之前小V在《wordpress二次开发教程手记:多站点的用户数据共享》一文中解决了多个wordpress站点之间用户数据的互通共享问题,但是小V发现如果用户在登录站点1后继续访问站点2,任然需要重新登录。这样对于用户体验是非常不友好的,但是目前没有很完美的解决办法。接下来小V就发一个不是很完美的代替方案,利用wpmu中的cookie共享方案来解决这个问题。
首先说下这种方法适用的在什么情况下使用:
次级域名之间的通行登陆,例如1.v7v3.com和2.v7v3.com之间通行登陆
同一个域名下不同目录之间互相登陆,例如v7v3.com和v7v3.com/site以及v7v3.com/site1之间通行登陆,而且cookie也不能跨浏览器。
操作步骤:
1、打开主站的wp-config.php,找到类似于以下代码的代码。
define('AUTH_KEY',         'E1hds(d)Pi#}15vM+:Vb2)+NO.2Z$V5t<ASxd]w1>T<xPe[<43*[5ekSGlnQ1<7l');
define('SECURE_AUTH_KEY',  '!R012(b1 *St4pMeicGuVm?<kuR7wO(X+|HSB.IbVlh[Sw`mDp{UW^,3cIpyi-jD');
define('LOGGED_IN_KEY',    '3|>)1#o>*y9UyTz3nG.]qg5*^}|wx1B)_1>])H+{Ofl[^a1l#~*;JYc<]0@#Zq1@');
define('NONCE_KEY',        '+|taP{aNL[-d,{-/vo&iC ++hO;zZcf|M48*Ju|#u8<,4TC*F&:uWdPHFqdzm()w');
define('AUTH_SALT',        ':-O^|#w&t_D)/w<bUwT_tk@S]D;ggDixOw<=I X+lTl]_@b~W## ;$D~xp^a=ka&');
define('SECURE_AUTH_SALT', 'IN]e6b@]pG2wyj[S)+pq5g3[%.+B^)L-{(n*866I&b-NWI2:Ey #+<+f~nyd-| &');
define('LOGGED_IN_SALT',   'O]6:#9@kn)./^ssR,42l4%8|M-Q($R=b~lY@EAj3?gcrPzj(@or4aSvV!CYq?hLI');
define('NONCE_SALT',       '7#4-+^_t|XO}kQc_X1t~)no3W!kG5rlbOt-*rj)]8?=c*;i1#=Nb$sBxcd]fve+L');
2. 拷贝主站wp-config.php中的AUTH_KEY和SECURE_AUTH_KEY到英文站的wp-config.php中,替换相应的行。如果嫌麻烦上面代码全部拷贝到英文站也可以。
3. 在主站和英文站的wp-config.php中创建下面代码,记得去生成一个复杂的随机字符串,不要直接拷贝,主站和英文站的SECRET_SALT值要相同
define('SECRET_SALT', 'Q$QuHIfQO^(CtrL5D(fcG$miB,fE2]-~::qoB,O_?o|TfgNfQB/x/kv$Tg1Aa7Hf');
(PS:以上代码不要直接复制本站给出的代码,你可以到https://api.wordpress.org/secret-key/1.1/salt/去生成一个。)
4. 在主站和英文站的wp-config.php中创建如下代码:
define('ADMIN_COOKIE_PATH', '/');
define('COOKIEPATH', '/');
define('SITECOOKIEPATH', '/');
define('COOKIEHASH', md5('用自己的随机字符串替换'));
5. 清除浏览器的cookie,选择其中一个网站登录,然后直接访问另一个网站的wp-admin,看是不是已经自动登陆了。
不同次级域名之间的通行登陆
在所有网站的wp-config.php中再加上
define('COOKIE_DOMAIN', 'v7v3.com'); //将v7v3.com换成你网站的根域名,必须是根域名!
至此就完成了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐