整合 ucenter 注册自动激活

2014/09/09 13:43
阅读数 5.9K

应用整合 UCenter,同步注册到 Discuz 的用户,在 Discuz 登录时得手动激活,用户体验很不好,不过解决方法很简单~
修改应用下的 ./uc_client/model/user.php 文件,大概在 138 行(UCenter 1.6)处的 function add_user 函数里添加代码:

function add_user($username, $password, $email, $uid = 0, $questionid = '', $answer = '', $regip = '') {
	$regip = empty($regip) ? $this->base->onlineip : $regip;
	$salt = substr(uniqid(rand()), -6);
	$password = md5(md5($password).$salt);
	$sqladd = $uid ? "uid='".intval($uid)."'," : '';
	$sqladd .= $questionid > 0 ? " secques='".$this->quescrypt($questionid, $answer)."'," : " secques='',";
	$this->db->query("INSERT INTO ".UC_DBTABLEPRE."members SET $sqladd username='$username', password='$password', email='$email', regip='$regip', regdate='".$this->base->time."', salt='$salt'");
	$uid = $this->db->insert_id();
	$this->db->query("INSERT INTO ".UC_DBTABLEPRE."memberfields SET uid='$uid'");
	// BEGIN
	$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member SET uid='$uid', username='$username', password='$password', email='$email', adminid='0', groupid='10', regdate='".$this->base->time."', credits='0', timeoffset='9999'");
	$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member_status SET uid='$uid', regip='$regip', lastip='$regip', lastvisit='".$this->base->time."', lastactivity='".$this->base->time."', lastpost='0', lastsendmail='0'");
	$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member_profile SET uid='$uid'");
	$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member_field_forum SET uid='$uid'");
	$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member_field_home SET uid='$uid'");
	$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member_count SET uid='$uid', extcredits1='0', extcredits2='0', extcredits3='0', extcredits4='0', extcredits5='0', extcredits6='0', extcredits7='0', extcredits8='0'");
	// END
	return $uid;
}

注意这些表都是 Discuz 的表,不是 UCenter 的表,不能使用 UC_DBTABLEPRE ! 我自己在 UCenter 配置文件 config.inc.php 中定义了 DISCUZ_DBTABLEPRE:

define('DISCUZ_DBTABLEPRE', '`ultrax`.pre_');



展开阅读全文
打赏
1
4 收藏
分享
加载中
如果是phpsso的同步,要修改的文件夹:phpsso_server\api\uc_client\model\user.php
因为配置文件在:phpsso_server\caches\configs,后台修改会覆盖
所以要加一行 udefine('DISCUZ_DBTABLEPRE', '`test_nexhome_bbs`.pre_');
// BEGIN 注册免激活
define('DISCUZ_DBTABLEPRE', '`test_nexhome_bbs`.pre_');
$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member SET uid='$uid', username='$username', password='$password', email='$email', adminid='0', groupid='10', regdate='".$this->base->time."', credits='0', timeoffset='9999'");
$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member_status SET uid='$uid', regip='$regip', lastip='$regip', lastvisit='".$this->base->time."', lastactivity='".$this->base->time."', lastpost='0', lastsendmail='0'");
$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member_profile SET uid='$uid'");
$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member_field_forum SET uid='$uid'");
$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member_field_home SET uid='$uid'");
$this->db->q
2016/07/05 14:49
回复
举报
我解决了激活失败的问题
楼主的方法试了,没用的
我这边只要
function add_user($username, $password, $email, $uid = 0, $questionid = '', $answer = '', $regip = '') {
}
中,加入以下代码即可
$this->db->query("INSERT INTO ".DISCUZ_DBTABLEPRE."common_member SET uid='$uid', username='$username', password='$password', email='$email', adminid='0', groupid='10',credits='0'");
若是不成功,请到素材火http://www.sucaihuo.com/联系我
2016/04/22 17:34
回复
举报
找了半天找到这里,问题跟楼上一样
2015/02/25 19:23
回复
举报

引用来自“青丝成雪”的评论

你好,请问下我按照这种方式修改好,没有生效。我手动到sql中执行上面的一条插入语句:
INSERT INTO discuz.pre_common_member_field_forum SET uid='11',discuz是我的数据库名,
结果提示:Field 'medals' doesn't have a default value,看了下数据库这张表该字段的定义是
`medals` text NOT NULL,确实不为空,那这个我在安装的时候或别的地方需要配置什么才能解决这个问题呢?
谢谢..

引用来自“斑驳”的评论

你是哪个版本的 Dsicuz?这段代码我前几个月用了一下是没问题的,你再试试吧
用的是3.2。但是我后面就自己在后面加语句,报哪个字段的错我就加如set medals='',直到不报错为止,但最后还是无法自动激活,非要先登陆一次才行
2014/12/22 19:48
回复
举报
斑驳博主

引用来自“青丝成雪”的评论

你好,请问下我按照这种方式修改好,没有生效。我手动到sql中执行上面的一条插入语句:
INSERT INTO discuz.pre_common_member_field_forum SET uid='11',discuz是我的数据库名,
结果提示:Field 'medals' doesn't have a default value,看了下数据库这张表该字段的定义是
`medals` text NOT NULL,确实不为空,那这个我在安装的时候或别的地方需要配置什么才能解决这个问题呢?
谢谢..
你是哪个版本的 Dsicuz?这段代码我前几个月用了一下是没问题的,你再试试吧
2014/12/21 15:49
回复
举报
你好,请问下我按照这种方式修改好,没有生效。我手动到sql中执行上面的一条插入语句:
INSERT INTO discuz.pre_common_member_field_forum SET uid='11',discuz是我的数据库名,
结果提示:Field 'medals' doesn't have a default value,看了下数据库这张表该字段的定义是
`medals` text NOT NULL,确实不为空,那这个我在安装的时候或别的地方需要配置什么才能解决这个问题呢?
谢谢..
2014/12/20 17:19
回复
举报
更多评论
打赏
6 评论
4 收藏
1
分享
返回顶部
顶部