完美整合phpcms v9和discuz X3.1实现同步登陆退出论坛免激活
<p>经过测试仍然有问题,phpcms登陆,论坛可以实现同步登陆,但论坛登陆phpcms无法同步登陆。但总体来说也能使用了。如果有更好的方法欢迎补充。</p>
<p>
<strong>整合原理:</strong></p>
<p>
UCenter 作服务端;phpsso 与 Discuz! 分别作 UCenter 的客户端应用;phpsso 与 Discuz! 通过 UCenter 发生交互。</p>
<p>
phpcms 通过 phpsso 与 Discuz! 发生交互。</p>
<p>
第一步:安装 phpcms V9 。安装 Discuz! X3.0 (同时安装 UCenter)。</p>
<p>
第二步:在 UCenter 中添加“phpsso 应用”。</p>
<p>
1、管理员登录 Discuz! X3.0 管理中心,进入“UCenter”,点击“应用管理”。</p>
<p>
2、点击“添加新应用”按钮,选择安装方式为”自定义安装“。在展开的”添加新应用“参数配置表中,各项参数配置如下:</p>
<p>
应用名称:phpsso</p>
<p>
应用的主 URL:http://localhost/phpcms/phpsso_server (必填, phpcms 安装路径,视实际情况而定,最后不要带斜线)</p>
<p>
应用 IP:(选填,正常情况下留空即可。如果由于域名解析问题导致 UCenter 与该应用通信失败,请尝试设置为该应用所在服务器的 IP 地址。)</p>
<p>
通信密钥:(必填,phpcms 的通信密钥必须与此设置保持一致,否则 phpsso 将无法与 UCenter 正常通信。)</p>
<p>
应用类型:其它(必选)</p>
<p>
应用的物理路径:(选填,默认留空)</p>
<p>
查看个人资料页面地址:(选填,URL中域名后面的部分,如:/space.php?uid=%s 这里的 %s 代表uid)</p>
<p>
应用接口文件名称:(选填,默认为uc.php)</p>
<p>
标签单条显示模板:(选填,默认留空)</p>
<p>
标签模板标记说明:(选填,默认留空)</p>
<p>
是否开启同步登录:是(可选,开启同步登录后,当用户在登录 Discuz! 时,同时也会登录 phpcms 。)</p>
<p>
是否接受通知:否(可选)</p>
<p>
3、提交后,将生成新的应用ID。(记住这个应用ID,在”第三步“中将用到它。)</p>
<p>
4、进入后台“站长”,“UCenter 设置”选项。"是否允许直接激活"一项,选择“是”。</p>
<p>
第三步:配置 phpsso 。</p>
<p>
1、管理员登录 phpcms V9 后台管理中心,进入“phpsso”,点击“系统设置”。</p>
<p>
2、在“系统设置”下的“UCenter配置”一栏中,各项参数配置如下:</p>
<p>
是否启用:是</p>
<p>
Ucenter api 地址:http://localhost/discuz/uc_server (必填,蓝色字体部分为 Discuz! 安装路径,视实际情况而定,最后不要带斜线)</p>
<p>
Ucenter api IP:(选填,一般不用填写,遇到无法同步时,请填写 UCenter 主机的IP地址)</p>
<p>
Ucenter 数据库主机名:localhost (必填,视实际情况而定)</p>
<p>
Ucenter 数据库用户名:root (必填,视实际情况而定)</p>
<p>
Ucenter 数据库密码:root (视实际情况而定)</p>
<p>
Ucenter 数据库名:discuz (必填,视实际情况而定)</p>
<p>
Ucenter 数据库表前缀:`discuz`.pre_ucenter_ (必填,视实际情况而定。如果此项填写错误,将导致 phpcms 无法注册新会员!)</p>
<p>
Ucenter 数据库字符集:UTF-8 (必选,视实际情况而定)</p>
<p>
应用id(APP ID):(必填,该值来在“第二步”中 UCenter 创建的 phpsso 应用时自动。)</p>
<p>
Ucenter 通信密钥:(必填,一定确保该值与在“第二步”中 UCenter 创建的 phpsso 应用密钥相同。)</p>
<p>
3、提交。</p>
<p>
第四步:查看通信状态。</p>
<p>
查看在 UCenter 中创建的 phpsso 应用与 UCenter 通信是否成功。</p>
<p>
如果通信成功,则进行下一步。</p>
<p>
如果通信失败,请检查“第二步”与“第三步”中的各项参数配置是否正确。</p>
<p>
第五步:备份 ./phpsso 。将 Discuz! X3 的 uc_client 复制到 phpsso_server/api/ 下,覆盖原来的 uc_client 。</p>
<p>
第六步:修改 Discuz! 会员登录相关</p>
<p>
1、修改 template\default\member\login.htm 第 36 行,删除</p>
<p>
onsubmit="{if $this->setting['pwdsafety']}pwmd5('password3_$loginhash');{/if}pwdclear = 1;ajaxpost('loginform_$loginhash', 'returnmessage_$loginhash', 'returnmessage_$loginhash', 'onerror');return false;"</p>
<p>
2、修改 template\default\member\login_s imple.htm 第 3 行,删除</p>
<p>
onsubmit="{if $_G['setting']['pwdsafety']}pwmd5('ls_password');{/if}return lsSubmit();"</p>
<p>
3、修改 /source/function/function_message.php 第 78 行,查找</p>
<p>
$param['header'] = true;</p>
<p>
替换为:</p>
<p>
$param['header'] = false;</p>
<p>
常见问题解答:</p>
<p>
1、整合完成后,在 phpcms 注册、登录均“失败”怎么办?</p>
<p>
答:这可能是由于无法连接到 UCenter 的原因。可以尝试修改文件</p>
<p>
phpsso_server/api/uc_client/model/base.php</p>
<p>
将第 74 行的 $this->db->connect(UC_DBHOST, UC_DBUSER, UC_DBPW, '', UC_DBCHARSET, UC_DBCONNECT, UC_DBTABLEPRE);</p>
<p>
复制代码替换为: $this->db->connect(UC_DBHOST, UC_DBUSER, UC_DBPW, UC_DBNAME, UC_DBCHARSET, UC_DBCONNECT, UC_DBTABLEPRE);</p>
<p>
复制代码2、为什么不使用官方自带的 UCenter 客户端?</p>
<p>
答:官方自带的 UCenter 客户端版本为 1.5.1 Release 20100501 ,而 Discuz! X3.0 使用的版本为 1.6.0 。版本不一致,无法整合成功。</p>
<p>
3、整合成功后,能达到怎样的效果?</p>
<p>
答:实现 phpcms 与 Discuz! 会员的双向同步注册、登录、退出等。</p>
<p>
4、第一次在 phpcms 注册的会员必须在 Discuz! 登录一次,下次才会同步登录。这正常吗?</p>
<p>
答:正常。因为 phpsso 作为 UCenter 的第三方应用,是需要在 Discuz! 登录激活的。</p>
<p>
如果您嫌在 Discuz! 激活麻烦,可以与我联系,我们将提供商业服务,帮您解决这个问题。</p>
<p>
5、会员在 phpcms 登录后,没有同步登录到 Discuz! 怎么办?</p>
<p>
答:这很可能是由于 phpsso 的“UCenter配置”有误引起的,请仔细检查各项参数设置。</p>
<p>
6、会员在 Discuz! 登录后,没有同步登录到 phpcms 怎么办?</p>
<p>
答:这很可能是由于 UCenter 的 phpsso 应用配置有误引起的,请仔细检查各项参数设置。</p>
<p>
分析其主要原因是phpsso与ucenter通信成功后,XXX_ucenter_member表中的用户已经同步成功但是在XXX_common_member中并没有此用户,所以只要在xxx_common_member中插入此用户就可以了,所以修改discuz/api/uc.php下找到function synlogin($get, $post)整段,修改为下面的内容:</p>
<blockquote>
<ol>
<li>
<span><span>function</span><span> synlogin($get, $post) { </span></span>
</li>
<li>
<span> global $_G; </span>
</li>
<li>
<span> </span>
</li>
<li>
<span> <span>if</span><span>(!API_SYNLOGIN) { </span></span>
</li>
<li>
<span> <span>return</span><span> API_RETURN_FORBIDDEN; </span></span>
</li>
<li>
<span> } </span>
</li>
<li>
<span> </span>
</li>
<li>
<span> header(<span>'P3P: CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR"'</span><span>); </span></span>
</li>
<li>
<span> </span>
</li>
<li>
<span> $cookietime = 31536000; </span>
</li>
<li>
<span> $uid = intval($get[<span>'uid'</span><span>]); </span></span>
</li>
<li>
<span> $query = DB::query(<span>"SELECT uid, username, password FROM "</span><span>.DB::table(</span><span>'common_member'</span><span>).</span><span>" WHERE uid='$uid'"</span><span>); </span></span>
</li>
<li>
<span> <span>if</span><span> ($member = DB::fetch($query)) </span></span>
</li>
<li>
<span> { </span>
</li>
<li>
<span> dsetcookie(<span>'auth'</span><span>, authcode(</span><span>"$member\t$member"</span><span>, </span><span>'ENCODE'</span><span>), $cookietime); </span></span>
</li>
<li>
<span> }<span>else</span><span> </span></span>
</li>
<li>
<span> { </span>
</li>
<li>
<span> $username = $get[<span>'username'</span><span>]; </span></span>
</li>
<li>
<span> $query = DB::query(<span>"SELECT uid, username, password, email FROM "</span><span>.DB::table(</span><span>'ucenter_members'</span><span>).</span><span>" WHERE username='$username'"</span><span>); </span></span>
</li>
<li>
<span> $member = DB::fetch($query); </span>
</li>
<li>
<span> $password = $member[<span>'password'</span><span>]; </span></span>
</li>
<li>
<span> $email = $member[<span>'email'</span><span>]; </span></span>
</li>
<li>
<span> $ip = $_SERVER[<span>'REMOTE_ADDR'</span><span>]; </span></span>
</li>
<li>
<span> $time = time(); </span>
</li>
<li>
<span> $userdata = array( </span>
</li>
<li>
<span> <span>'uid'</span><span>=>$uid, </span></span>
</li>
<li>
<span> <span>'username'</span><span>=>$username, </span></span>
</li>
<li>
<span> <span>'password'</span><span>=>$password, </span></span>
</li>
<li>
<span> <span>'email'</span><span>=>$email, </span></span>
</li>
<li>
<span> <span>'adminid'</span><span>=>0, </span></span>
</li>
<li>
<span> <span>'groupid'</span><span>=>10, </span></span>
</li>
<li>
<span> <span>'regdate'</span><span>=>$time, </span></span>
</li>
<li>
<span> <span>'credits'</span><span>=>0, </span></span>
</li>
<li>
<span> <span>'timeoffset'</span><span>=>9999 </span></span>
</li>
<li>
<span> ); </span>
</li>
<li>
<span> DB::insert(<span>'common_member'</span><span>, $userdata); </span></span>
</li>
<li>
<span> </span>
</li>
<li>
<span> $status_data = array( </span>
</li>
<li>
<span> <span>'uid'</span><span> => $uid, </span></span>
</li>
<li>
<span> <span>'regip'</span><span> => $ip, </span></span>
</li>
<li>
<span> <span>'lastip'</span><span> => $ip, </span></span>
</li>
<li>
<span> <span>'lastvisit'</span><span> => $time, </span></span>
</li>
<li>
<span> <span>'lastactivity'</span><span> => $time, </span></span>
</li>
<li>
<span> <span>'lastpost'</span><span> => 0, </span></span>
</li>
<li>
<span> <span>'lastsendmail'</span><span> => 0 </span></span>
</li>
<li>
<span> ); </span>
</li>
<li>
<span> DB::insert(<span>'common_member_status'</span><span>, $status_data); </span></span>
</li>
<li>
<span> DB::insert(<span>'common_member_profile'</span><span>, array(</span><span>'uid'</span><span> => $uid)); </span></span>
</li>
<li>
<span> DB::insert(<span>'common_member_field_forum'</span><span>, array(</span><span>'uid'</span><span> => $uid)); </span></span>
</li>
<li>
<span> DB::insert(<span>'common_member_field_home'</span><span>, array(</span><span>'uid'</span><span> => $uid)); </span></span>
</li>
<li>
<span> DB::insert(<span>'common_member_count'</span><span>, array(</span><span>'uid'</span><span> => $uid)); </span></span>
</li>
<li>
<span> DB::query(<span>'UPDATE '</span><span>.DB::table(</span><span>'common_setting'</span><span>).</span><span>" SET svalue='$username' WHERE skey='lastmember'"</span><span>); </span></span>
</li>
<li>
<span> $query = DB::query(<span>"SELECT uid, username, password FROM "</span><span>.DB::table(</span><span>'common_member'</span><span>).</span><span>" WHERE uid='$uid'"</span><span>); </span></span>
</li>
<li>
<span> <span>if</span><span> ($member = DB::fetch($query)) </span></span>
</li>
<li>
<span> { </span>
</li>
<li>
<span> dsetcookie(<span>'auth'</span><span>, authcode(</span><span>"$member\t$member"</span><span>, </span><span>'ENCODE'</span><span>), $cookietime); </span></span>
</li>
<li>
<span> } </span>
</li>
<li>
<span> } </span>
</li>
<li>
<span> } </span>
</li>
</ol>
</blockquote>
頁:
[1]