站长之家 - 站长资讯 - 易采站长站

当前位置: > 建站教程 > 源码教程 > CMS 教程 >

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

2019-10-06 12:28 | 来源:易采站长站 | 编辑:admin |

点评:之前写过《【Discuz】自动同步登陆的完美解决办法》,主要是解决Discuz的同步登陆问题,用户系统是采用UCenter进行管理的。     最近的一次应用是基本完成了业务系统,需要整合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要保证唯一。

软件名称:
Discuz论坛系统下载
软件语言:
简体/多国语言
软件授权:
个人免费

  • discuz不能同步登陆ecmall的解决办法-ECshop教程
  • ECShop整合Discuz实现会员同步登陆和退出-ECshop教程
  • Phpcms v9 整合Discuz! X2.5 和UCenter 1.6.0详细图文教程-PhpCms教程
  • 解决phpcms V9整合discuz! X3.0后 在phpcms新注册用户需要在discuz激活的问题
  • 完美整合phpcms v9和discuz X3.1实现同步登陆退出论坛免激活-PhpCms教程
  • phpcmsv9和discuz同步登陆同步退出教程-PhpCms教程
  • Discuz如何设置DIY模块 DIY模块安装图文教程-Discuz!教程
  • DISCUZ论坛后台管理员登录后会自动退出登录的解决方法-Discuz!教程
  • discuz论坛程序何如添加二级导航?-Discuz!教程
  • Discuz登录后总是显示未登录状态怎么办?-Discuz!教程
  • 网友评论

    关于我们 - 联系我们 - 广告服务 - 版权声明 - 人才招聘 - 友情链接 - 网站地图 - 帮助 - -

    CopyRight © 2010-2016 源码下载 easck.com , All Rights Reserved

    蒙公网安备 15052402000103号

    蒙ICP备14002389-1号