一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

DEDECMS|帝國CMS|Discuz|PHPCMS|Wordpress|ZBLOG|ECSHOP|蘋果CMS|極致CMS|CMS系統|

服務器之家 - 建站程序 - Discuz - Discuz 完美集成進現有系統(整合用戶和版面增刪)

Discuz 完美集成進現有系統(整合用戶和版面增刪)

2019-09-29 15:21Discuz教程網 Discuz

之前寫過《【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 = "[email protected]"; // 注冊郵箱,不能重復 
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要保證唯一。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美亚洲综合另类 | 亚洲AV久久无码精品九号 | 日产乱码卡一卡2卡三卡四福利 | 国产精品毛片va一区二区三区 | 69午夜影院 | 日本一区二区精品88 | 精品一区二区三区在线成人 | 999精品视频这里只有精品 | 国产自产在线 | 亚洲国产日韩欧美一区二区三区 | 日本高清视频一区二区 | 特级毛片全部免费播放器 | 日本人妖网站 | 久久久久九九 | 国产精品视频第一页 | 国产成人久久精品推最新 | 欧美乱理伦另类视频 | 香港论理午夜电影网 | 国产精品视频免费观看 | 韩日视频在线 | 日韩欧美一区二区在线 | 非洲一级毛片又粗又长aaaa | 亚色九九九全国免费视频 | 男人猛进女人屁股免费 | 四虎影库网址 | 国产精品嫩草影院一二三区入口 | 免费的伦理片 | 久久99热在线观看7 久久99精品涩AV毛片观看 | 青青青手机视频在线观看 | h玉足嫩脚嗯啊白丝 | 苍井空av | 亚洲精品久久久久AV无码 | 精品免费看 | 色悠久久久久综合欧美99 | 羞羞答答影院在线 | 成人免费一区二区三区在线观看 | 秋霞理论一级在线观看手机版 | 美女国内精品自产拍在线播放 | 欧美精品国产第一区二区 | 女同志 videos | 美女黑人做受xxxxxⅹ |