Discuz 完美集成进现有系统(整合用户和版面增删)

所属分类: CMS教程 / discuz 阅读数: 1914
收藏 0 赞 0 分享
最近的一次应用是基本完成了业务系统,需要整合Discuz进去作为交流版块使用。于是,涉及到用户系统的整合和版面的增删操作。UCenter提供了API进行用户的增删管理,自然可以用,但为了保证用户id的统一性,暴力地绕过了UCenter API,而采用直接操作数据库的方式来完成用户增删,当然版面的增删也是操作数据库来完成。

1、增加用户到Discuz和UCenter的代码

复制代码
代码如下:

$uid = 100; // 用户编号
$username = "maple"; // 用户名
$password = "mypassword"; // 用户密码
$salt = md5((string)rand()); // 随机字符用于加密
$password = md5(md5($pwd) . $salt); // 加密后的密码
$groupid = 10; // 用户组编号
$timestamp = time(); // 时间戳
$bbsemail = "i@witmax.cn"; // 注册邮箱,不能重复
execute_sql("INSERT INTO cdb_members (uid, username, password, secques, gender, adminid, groupid, regip, regdate, lastvisit, lastactivity, posts, credits, email, bday, sigstatus, tpp, ppp, styleid, dateformat, timeformat, showemail, newsletter, invisible, timeoffset) VALUES ('$uid', '$username', '$salt', '$password', '0', '0', '$groupid', 'Manual Acting', '$timestamp', '$timestamp', '$timestamp', '0', '0', '$bbsemail', '0000-00-00', '0', '0', '0', '0', '0', 'H:i', '1', '1', '0', '8')");
execute_sql("INSERT INTO cdb_memberfields (uid) VALUES ('$uid')");
execute_sql("INSERT INTO `cdb_uc_members` SET uid='$uid', username='$username', password='$password', email='$bbsemail', regip='Manual Acting', regdate='$timestamp', salt='$salt'");

2、在Discuz和UCenter中删除用户的代码

复制代码
代码如下:

$uid = 100; // 要删除的用户编号
execute_sql("DELETE FROM `cdb_members` WHERE uid=$uid");
execute_sql("DELETE FROM `cdb_memberfields` WHERE uid=$uid");
execute_sql("DELETE FROM `cdb_uc_members` WHERE uid=$uid");
execute_sql("DELETE FROM `cdb_uc_memberfields` WHERE uid=$uid");

3、在Discuz中增加版面并设置版主的代码

复制代码
代码如下:

$uid = 100; // 版主用户编号
$fid = 100; // 版面编号,需要保证不与现有版面编号重复
$forum_name = "Test Forum"; // 版面名称
execute_sql("INSERT INTO `cdb_forums` (`fid`, `fup`, `type`, `name`, `status`, `displayorder`, `styleid`, `threads`, `posts`, `todayposts`, `lastpost`, `allowsmilies`, `allowhtml`, `allowbbcode`, `allowimgcode`, `allowmediacode`, `allowanonymous`, `allowshare`, `allowpostspecial`, `allowspecialonly`, `alloweditrules`, `allowfeed`, `recyclebin`, `modnewposts`, `jammer`, `disablewatermark`, `inheritedmod`, `autoclose`, `forumcolumns`, `threadcaches`, `alloweditpost`, `simple`, `modworks`, `allowtag`, `allowglobalstick`) VALUES
('$fid', 3, 'forum', '$forum_name', 1, 0, 0, 0, 0, 0, '', 1, 0, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1);");
execute_sql("INSERT INTO `cdb_forumfields` (`fid`, `description`, `password`, `icon`, `postcredits`, `replycredits`, `getattachcredits`, `postattachcredits`, `digestcredits`, `redirect`, `attachextensions`, `formulaperm`, `moderators`, `rules`, `threadtypes`, `threadsorts`, `viewperm`, `postperm`, `replyperm`, `getattachperm`, `postattachperm`, `keywords`, `supe_pushsetting`, `modrecommend`, `tradetypes`, `typemodels`, `threadplugin`, `extra`) VALUES ('$fid', '', '', '', '', '', '', '', '', '', '', 'a:5:{i:0;s:0:\"\";i:1;s:0:\"\";s:5:\"medal\";N;s:7:\"message\";s:0:\"\";s:5:\"users\";s:0:\"\";}', '', '', '', '', ' 9 10 11 12 13 14 15 20 21 16 17 18 19 1 2 3 4 5 6 7 8 ', ' 20 21 1 2 3 ', ' 20 21 1 2 3 ', ' 20 21 1 2 3 ', ' 20 21 1 2 3 ', '', '', 'a:8:{s:4:\"open\";s:1:\"0\";s:3:\"num\";i:10;s:8:\"imagenum\";i:5;s:10:\"imagewidth\";i:200;s:11:\"imageheight\";i:150;s:9:\"maxlength\";i:0;s:9:\"cachelife\";i:900;s:8:\"dateline\";i:0;}', '', '', 'N;', 'a:1:{s:9:\"namecolor\";s:0:\"\";}');");
execute_sql("UPDATE cdb_members SET adminid='3' WHERE uid='$uid'");
execute_sql("INSERT INTO cdb_moderators (uid, fid, inherited) VALUES ('$uid', '$fid', '1')");

4、在Discuz中删除版面并取消版主管理权限的代码

复制代码
代码如下:

$uid = 100; // 要删除版面的版主用户编号
$fid = 100; // 要删除的版面编号
execute_sql("DELETE FROM cdb_forums WHERE fid='$fid'");
execute_sql("DELETE FROM cdb_forumfields WHERE fid='$fid'");
execute_sql("DELETE FROM cdb_moderators WHERE fid='$fid'");
execute_sql("UPDATE cdb_members SET adminid='0' WHERE uid='$uid'");

直接操作数据库的好处是业务逻辑简单,操作方便,与现有系统整合容易;缺点就是很流氓很暴力,需要保证操作数据的有效性,如增加的版面的fid要保证唯一。
更多精彩内容其他人还在看

DiscuzX发帖默认隐藏附件/图片/链接/视频等设置教程

DiscuzX在发帖过程中会有很多我们不想看到的选项可以默认隐藏附件/图片/链接/视频吗?答案是可以的,感兴趣的你可以参考下本文哈,希望可以帮助到你
收藏 0 赞 0 分享

Discuz!x3版块及分区可选择性设置是否显示在导航中

很多站长长年累月的自己把导航改完又改,无非是想把自己的版块都一目了然的放上去导航中,很容易实现的效果却变得如此复杂,Discuz!x3新功能帮助站长朋友们实现了这一点,感兴趣的你可以不要错过本文了哈
收藏 0 赞 0 分享

Discuz! X2.5与UCenter通信失败常见症状及解决方法

UCenter通信失败是Discuz站长们经常遇见的问题之一;如上传头像时报错、新会员无法注册、登录密码不正确等一系列的问题,接下来与大家分享UCenter 通信失败的解决方法
收藏 0 赞 0 分享

Discuz! X2.5定时发帖新功能开启方法(图文)

Discuz! X2.5新增了很多功能,比如定时发帖,很方便的功能会节省很多的时间,听说安装之后无法实现,接下来为大家详细介绍下到底该如何设置,感兴趣的你可千万不要错过了哈,希望可以帮助到你
收藏 0 赞 0 分享

Discuz如何设置腾讯微博来源(图文步骤)

在微博开放平台创建应用后,请提交审核,应用通过审核后来源才能生效,来源生效后微博才会显示您的网站名称哦,感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

Discuz!开启使用HTML、主题分类、分类信息的方法

好多新手站长对于HTML的开启、使用,分类信息的开启、使用都很茫然,不知道从哪里下手,或者自己设置了但是却不能正常使用。希望下面的讲解对这些新手站长有所帮助
收藏 0 赞 0 分享

discuz不修改代码达到允许referer跳转到同顶级域名的解决方案

查看了discuz的drerferer方法.发现它不允许跳转到不同子域名的跳转,下面与大家分享下使用一个不变动的方式来增加跳转功能,感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

discuz 批量删除的sql命令小结

这篇文章主要介绍了discuz 批量删除内容的一些sql语句,比去后台选择的方便
收藏 0 赞 0 分享

discuz修改太阳、月亮、星星等默认等级图标的方法

想修改一下默认的等级图标,先把你的等级图片在论坛用附件的形式发表在帖子中,然后按右键查看属性,这就是要替换的地址,具体的修改方法如下,有需要的朋友可以参考下,希望对大家有所帮助
收藏 0 赞 0 分享

Discuz 模板目录结构注释说明详细整理

本文为大家整理了一些使用使用是常接触的Discuz 模板目录结构与注释说明,有需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多