discuz 完美集成進現有系統(整合用戶和版面增刪)
來源:易賢網 閱讀:967 次 日期:2016-06-28 10:25:20
溫馨提示:易賢網小編為您整理了“discuz 完美集成進現有系統(整合用戶和版面增刪)”,方便廣大網友查閱!

最近的一次應用是基本完成了業(yè)務系統,需要整合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');

直接操作數據庫的好處是業(yè)務邏輯簡單,操作方便,與現有系統整合容易;缺點就是很流氓很暴力,需要保證操作數據的有效性,如增加的版面的fid要保證唯一。

更多信息請查看CMS教程
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢?yōu)闇剩?/div>
相關閱讀CMS教程

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權所有:易賢網