查看: 60325|回复: 42

[分 享] phpcms v9 与 DZ最新版整合补充说明。

    [复制链接]
发表于 2014-4-2 16:21:59 | 显示全部楼层 |阅读模式
之前@haoguoxin分享出来的,关于V9与UC的整合教程,有部分同学反馈整合失败。对于可能的原因,做个分享。  

原贴地址: http://bbs.phpcms.cn/thread-879541-1-1.html    

整合的前6步部分,按原帖走即可。出现问题请检查配置和缓存的更新,需要重点关注的几点地方是:

应用ID、密钥、以及UC的表名前缀(UC数据库表前缀的格式为“ `数据库名`.数据库前缀 ”,注意数据库名的不是单引号。是数字键1左边的`号)





对于第7步,对discuz/api/uc.ph 里function synlogin($get, $post)函数的修改,如下示例。

如果V9登陆而论坛没有同步登陆,请尝试下面的方法。
A. 如果UC的表前缀和DZ的表前缀不一致,可根据实际情况使用下面一行代码,替换下面函数里红色代码部分。(UC表名: 为你的UC的会员表名。要根据情况替换为你自己的UC会员表名)
$query = DB::query("SELECT uid, username, password, email FROM UC表名WHERE username='$username'");


如我的UC表为cdb_uc_members , 如图所示:

需要使用的代码如下:
$query = DB::query("SELECT uid, username, password, email FROM cdb_uc_members WHERE username='$username'");





function synlogin($get, $post) {
        global $_G;

        if(!API_SYNLOGIN) {
            return API_RETURN_FORBIDDEN;
        }

        header('P3P: CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR"');

        $cookietime = 31536000;
        $uid = intval($get['uid']);
        $query = DB::query("SELECT uid, username, password FROM ".DB::table('common_member')." WHERE uid='$uid'");
        if ($member = DB::fetch($query))
        {
            dsetcookie('auth', authcode("$member[password]\t$member[uid]", 'ENCODE'), $cookietime);
        }else
        {
            $username = $get['username'];
            $query = DB::query("SELECT uid, username, password, email FROM ".DB::table('ucenter_members')." WHERE username='$username'");
            $member = DB::fetch($query);
            $password = $member['password'];
            $email = $member['email'];
            $ip = $_SERVER['REMOTE_ADDR'];
            $time = time();
            $userdata = array(
                'uid'=>$uid,
                'username'=>$username,
                'password'=>$password,
                'email'=>$email,
                'adminid'=>0,
                'groupid'=>10,
                'regdate'=>$time,
                'credits'=>0,
                'timeoffset'=>9999
            );
            DB::insert('common_member', $userdata);

            $status_data = array(
                'uid' => $uid,
                'regip' => $ip,
                'lastip' => $ip,
                'lastvisit' => $time,
                'lastactivity' => $time,
                'lastpost' => 0,
                'lastsendmail' => 0
            );
            DB::insert('common_member_status', $status_data);
            DB::insert('common_member_profile', array('uid' => $uid));
            DB::insert('common_member_field_forum', array('uid' => $uid));
            DB::insert('common_member_field_home', array('uid' => $uid));
            DB::insert('common_member_count', array('uid' => $uid));
            DB::query('UPDATE '.DB::table('common_setting')." SET svalue='$username' WHERE skey='lastmember'");
            $query = DB::query("SELECT uid, username, password FROM ".DB::table('common_member')." WHERE uid='$uid'");
            if ($member = DB::fetch($query))
            {
                dsetcookie('auth', authcode("$member[password]\t$member[uid]", 'ENCODE'), $cookietime);
            }
        }
    }

发表于 2014-4-3 16:30:14 | 显示全部楼层
hetoo 发表于 2014-4-3 11:25
收藏备用,感谢分享

   付费求帮忙开发伪静态。
回复 支持 0 反对 1

使用道具 举报

发表于 2014-4-2 16:32:54 | 显示全部楼层
用最新的不用这样搞也行咯
回复 支持 反对

使用道具 举报

发表于 2014-4-2 17:38:52 | 显示全部楼层
谢谢分享、。。
回复 支持 反对

使用道具 举报

发表于 2014-4-3 08:26:02 | 显示全部楼层
谢谢楼主,虽然没怎么用论坛,收藏下,备用
回复 支持 反对

使用道具 举报

发表于 2014-4-3 08:36:01 | 显示全部楼层
官方终于出点实用点的教程了
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-4-3 08:59:03 | 显示全部楼层
czlhw 发表于 2014-4-2 16:32
用最新的不用这样搞也行咯



如果UC和论坛表前缀一至的话(大部分情况),不会出现这个问题。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-4-3 08:59:41 | 显示全部楼层
邪恶 发表于 2014-4-2 17:38
谢谢分享、。。




  

回复 支持 反对

使用道具 举报

发表于 2014-4-3 11:25:25 | 显示全部楼层
收藏备用,感谢分享
回复 支持 反对

使用道具 举报

发表于 2014-4-3 16:39:15 | 显示全部楼层
收藏备用,感谢分享
回复 支持 反对

使用道具 举报

发表于 2014-4-3 21:03:57 | 显示全部楼层
dz和UC通信失败 不是禁用函数的事 还有其他原因吗?
回复 支持 反对

使用道具 举报

发表于 2014-4-9 10:41:29 | 显示全部楼层
收藏先 以后说不定 要用~
回复 支持 反对

使用道具 举报

发表于 2014-4-11 15:33:05 | 显示全部楼层
以前很早不就出了整合教程了么
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 点击这里注册

本版积分规则

小黑屋|Archiver|phpcms网站管理系统 ( 京ICP备14011169 )

GMT+8, 2017-10-19 14:55 , Processed in 0.352553 second(s), 11 queries , Memcache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表