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

最近的一次应用是基本完成了业务系统,需要整合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要保证唯一。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Java 应用中,你可以使用 Discuz API 来实现用户信息的同步和管理。首先,你需要在 Discuz 后台中开启 API 功能,然后获取 API 地址和密钥。然后,在 Java 应用中使用 HTTP 请求来调用 Discuz API,实现用户信息的同步和管理。 具体来说,你可以使用 Discuz API 中的用户相关接口,比如用户注册、用户登录、用户信息查询、用户信息修改等。你还可以使用 Discuz API 中的其他接口,来实现其他功能,比如发帖、回复、点赞等。 举个例子,如果你想实现在 Java 应用中注册 Discuz 用户,你可以使用以下代码: ``` String apiUrl = "https://www.discuz.com/api/user/register"; String apiKey = "your_api_key"; Map<String, String> params = new HashMap<>(); params.put("username", "user1"); params.put("password", "password1"); params.put("email", "[email protected]"); String signature = generateSignature(apiKey, params); params.put("signature", signature); HttpResponse response = post(apiUrl, params); int statusCode = response.getStatusLine().getStatusCode(); if (statusCode == 200) { // 注册成功 } else { // 注册失败 } ``` 在这段代码中,`generateSignature` 函数用于生成签名,`post` 函数用于发送 HTTP POST 请求。你需要根据自己的实际情况实现这两个函数。 希望这对你有帮助。 ### 回答2: 要实现Java和DISCUZ应用之间的用户信息同步和管理,我们可以采用以下步骤: 1. 创建Java应用的用户管理模块:在Java应用中,我们可以实现一个用户管理模块,用于处理用户的注册、登录、修改信息等操作。该模块需要包含用户信息的数据结构,并提供相应的接口和方法。 2. 创建DISCUZ应用的用户管理模块:同样地,我们需要在DISCUZ应用中实现一个用户管理模块,用于处理用户的注册、登录、修改信息等操作。该模块的功能需要与Java应用中的用户管理模块相对应,并且能够与DISCUZ的数据库行交互。 3. 同步用户信息:为了实现用户信息的同步,我们可以通过调用Java应用的接口,将用户注册、修改信息等操作发送给Java应用。Java应用在收到请求后,可以将相应的用户信息同步到DISCUZ应用的数据库中。 4. 维护用户一致性:为了保持用户信息的一致性,我们需要在Java应用和DISCUZ应用之间建立一个同步机制。这可以通过定期检查用户信息的更新情况,并将需要同步的数据行更新来实现。 5. 统一用户登录:为了让用户能够在Java和DISCUZ应用之间行无缝切换,我们可以实现单一登录机制。这可以通过在Java应用中创建一个登录模块,并行相应的验证和权限管理,将已登录的用户信息传递给DISCUZ应用,实现无需重复登录的功能。 通过上述步骤,我们可以实现Java和DISCUZ应用之间的用户信息同步和管理。这样一来,用户可以在Java和DISCUZ应用之间共享同一份用户信息,并且能够实现无缝切换和单一登录的操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值