最近在整JAVA和UCENTER的东西,受限于项目架构须要,没法彻底以UCENTER为中心,因此在对接过程当中遇到了许多不愉快的事情。经历多番研究,终于解决了其中了两个大问题,现记录下来,以备往后查看。php
项目并不要求用户注册时填写email,但UCENTER API要求必须输入email才能够经过验证,不得已必须得修改UCENTER代码才能绕过。如下是改动的代码:api
/uc_server/control/user.php 69行:cookie
1 // NOTE: 解决email必须填写的问题 2 //if(($status = $this->_check_email($email)) < 0) { 3 // return $status; 4 //}
因为BBS屏蔽了DISCUZ自带的注册、登陆、找密等操做,因此必需要实现单点登陆。当中遇到了一个很是蛋疼的问题:主站注册的帐户同步到UCENTER以后,UCENTER并不会通知其余应用,也就是说默认状况下,其余应用(包括DISCUZ在内)没法在新用户注册以后当即更新用户列表。细细研究以后发现,DISCUZ是在本地注册、登陆等事件中才会与UCENTER同步。这致使了,在主站新注册的用户,没法在BBS单点登陆成功——由于在BBS中根本不存在这个用户。解决的方法有两个,一是用户手工登陆一次BBS,BBS自带的机制会自动将用户信息从UCENTER同步过来;二是修改DISCUZ系统代码,在单点登陆请求时自动同步用户数据。在权衡了各方面因素以后,决定采用第二套方案。如下是改动的代码:架构
/api/uc.php 192行:dom
1 // NOTE 解决用户必须手工登陆1次论坛的问题 2 $member = getuserbyuid($uid, 1); 3 4 if (!$member) { 5 $init_arr = explode(',', $_G['initcredits']); 6 $groupid = $_G['regverify'] ? 8 : $_G['newusergroupid']; 7 8 C::t('common_member')->insert($uid, $get['username'], md5(random(10)), $get['email'], $_G['clientip'], $groupid, $init_arr); 9 10 $member = getuserbyuid($uid, 1); 11 } 12 13 if($member) { 14 dsetcookie('auth', authcode("$member[password]\t$member[uid]", 'ENCODE'), $cookietime); 15 }