分享
 
 
 

Discuz!论坛程序的使用技巧

王朝other·作者佚名  2006-11-23
窄屏简体版  字體: |||超大  

Discuz!4.1多论坛数据合并实战

作者:鱼鱼 阿贱

为了将资源集合在一处更好的进行推广,今天决定将定将1001pet(源论坛)和1001cate(源论坛)合并到娱乐-1001year(目标论坛)中合并到一起,组成一个新的论坛。前提:数据不能丢失、用户信息不能丢失。说干就干,现在开始吧。

工具:UltraEdit、PHPMYADMIN、MYSQL Administrator;

小贴士:为了保证数据的安全,鱼鱼建议大家将数据库保存在本地机器来操作,以免由于误操作造成对原论坛数据的损坏。

第一步:备份1001Year和1001Cate论坛的数据。

登录后台,将两个论坛(1001Year和1001Pet)的数据库分卷全部备份,并下载到本地。

第二步,建立两个新论坛。

在本地配置PHP+MYSQL环境,并安装UltraEdit、PHPMYADMIN、MYSQL、Administrator。然后新建两个论坛1001Year和1001Cate,并将两个数据库分别恢复到两个论坛中。

1:数据库中主要表格的作用。

cdb_buddys 好友信息表

cdb_favorites 个人收藏信息表

cdb_memberfields 用户扩展信息数据表

cdb_members 用户基本信息数据表

cdb_onlinetime 在线时间信息表

cdb_polls 投票帖子信息表

cdb_threads 主题帖子信息表

cdb_threadsmod 主题操作记录信息表

cdb_posts 帖子信息表

cdb_ratelog 帖子评分记录信息表

cdb_attachments 附件信息表

cdb_forumfields 论坛扩展信息数据表

cdb_forums 论坛基本信息表

cdb_moderators 斑竹信息数据表

cdb_pms 短信数据表

cdb_forumlinks 友情连接数据表

cdb_admingroups 管理组数据表

cdb_usergroups 用户组数据表

解释:在这里面,关键的就是cdb_members,cdb_memberfields,cdb_onlinetime,cdb_threads和cdb_posts。

2:由于三个论坛都同,很多会员在三个论坛上都进行了注册,包括鱼鱼也是这样。但是会员中不允许有重名的,在合并中如果不注意此点将导致部分信息重叠丢失。还好,鱼鱼的三个论坛都不大,鱼鱼方法是在会员注册的地方,一个一个试重名,试到重名的就记录下来,然后进行对用户名略做修改,并通知用户。期望,Discuz!写一个专门用来检测重名的PHP程序,给予合并论坛中帮助。

第三步:合并数据库。

备份数据的时候,尽量只备份有内容帖子的数据。为了避免麻烦,把2级目录的东西都转到了1级论坛下,这样合并的时候,在目标论坛上就不用建立太多版块。

1:在1001Year中建立1001cate和1001pet的板块,然后记录1001cate和1001pet在1001year论坛对应的fid(就是版块号,鼠标放到论坛首页各个版块的文字上面就可以在状态栏看到版块号了)。

本步骤解释:为了帖子准确和不出现错误,必须将所有板块全部记录完整,为了帖子对应,一定要详细。

2:因为还牵扯到会员重名的问题,毕竟我们都不会PHP只能手动操作,数据大的论坛最好找个高手写个程序检测。

在检测完会员后,需要升级数据库,如下:

CODE:

[Copy to clipboard] <http://www.discuz.net/thread-281886-1-2.html###>

UPDATE `cdb_members` SET `username` = '臭鱼old' WHERE `username` = '臭鱼';

本步骤解释:这里是将会员里叫“臭鱼”的用户改名为“臭鱼old”,用户名任意,在此只是举例。

3:

1)数据库升级一:主题+帖子+会员+附件的升级。

注意:这里所说的数据库升级,都是在原论坛进行的!因为要把数据合并到目标论坛,保持目标论坛数据不动。

也就是上面所说的那些重要的表,代码如下:

[Copy to clipboard] <http://www.discuz.net/thread-281886-1-2.html###>

UPDATE cdb_memberfields SET uid=uid+1839;

UPDATE cdb_members SET uid=uid+1839;

UPDATE cdb_threads SET authorid=authorid+1839;

UPDATE cdb_posts SET authorid=authorid+1839;

UPDATE cdb_threads SET tid=tid+3522;

UPDATE cdb_posts SET tid=tid+3522;

UPDATE cdb_posts SET pid=pid+23397;

UPDATE cdb_attachments SET tid=tid+3522;

UPDATE cdb_attachments SET pid=pid+23397;

UPDATE cdb_attachments SET aid=aid+8000;

当然,这里你要根据你目标论坛的会员数、主题数、帖子数和附件数量进行设置,比如:

[Copy to clipboard] <http://www.discuz.net/thread-281886-1-2.html###>

UPDATE cdb_memberfields SET uid=uid+1839;

根据我的目标论坛的会员数,最后一个UID是1839,这样升级的时候就将源论坛里的UID全部加1839。其他表内的数据也是根据这个来的,包括发贴量、主题数,都可以在你论坛看到。附件可以在后台查看ID号。

2)数据库升级二:版块的升级。

这里说的版块的升级,就是为了将源论坛的版块对应目标论坛新建的版块。代码如下:

[Copy to clipboard] <http://www.discuz.net/thread-281886-1-2.html###>

UPDATE cdb_threads SET fid=105 WHERE fid=41;

UPDATE cdb_threads SET fid=106 WHERE fid=42;

UPDATE cdb_threads SET fid=107 WHERE fid=27;

UPDATE cdb_threads SET fid=109 WHERE fid=38;

UPDATE cdb_threads SET fid=108 WHERE fid=34;

UPDATE cdb_threads SET fid=110 WHERE fid=13;

UPDATE cdb_threads SET fid=113 WHERE fid=17;

UPDATE cdb_threads SET fid=112 WHERE fid=16;

UPDATE cdb_threads SET fid=111 WHERE fid=15;

UPDATE cdb_threads SET fid=115 WHERE fid=43;

UPDATE cdb_threads SET fid=114 WHERE fid=19;

UPDATE cdb_threads SET fid=116 WHERE fid=14;

UPDATE cdb_threads SET fid=117 WHERE fid=23;

UPDATE cdb_threads SET fid=118 WHERE fid=25;

UPDATE cdb_threads SET fid=119 WHERE fid=26;

UPDATE cdb_posts SET fid=105 WHERE fid=41;

UPDATE cdb_posts SET fid=106 WHERE fid=42;

UPDATE cdb_posts SET fid=107 WHERE fid=27;

UPDATE cdb_posts SET fid=109 WHERE fid=38;

UPDATE cdb_posts SET fid=108 WHERE fid=34;

UPDATE cdb_posts SET fid=110 WHERE fid=13;

UPDATE cdb_posts SET fid=113 WHERE fid=17;

UPDATE cdb_posts SET fid=112 WHERE fid=16;

UPDATE cdb_posts SET fid=111 WHERE fid=15;

UPDATE cdb_posts SET fid=115 WHERE fid=43;

UPDATE cdb_posts SET fid=114 WHERE fid=19;

UPDATE cdb_posts SET fid=116 WHERE fid=14;

UPDATE cdb_posts SET fid=117 WHERE fid=23;

UPDATE cdb_posts SET fid=118 WHERE fid=25;

UPDATE cdb_posts SET fid=119 WHERE fid=26;

例如:UPDATE cdb_threads SET fid=105 WHERE fid=41;

41是源论坛的fid号,105即目标论坛新建的同样版块的fid号。

提示:以上的数据库升级,都是在源论坛操作,而不是在要合并到的目标论坛中操作。

4:数据升级完以后该合并了,这里用到了UE。

把合并完的数据,用4.1或者PHPMYADMIN的备份功能,将单独的表备份出来。例如:我先合并会员,就备份出cdb_memberfields表和cdb_members表。

然后用UE打开,将源论坛中的数据复制到目标论坛的数据。例如:会员的合并。

在源论坛的数据库中查找cdb_memberfields,下面的INSERT INTO的内容,直到-- 表的结构 `cdb_members`前,全都是。全部复制,然后粘贴到目标论坛的cdb_memberfields表的最后。其他表的操作同上。按照此操作,将帖子、主题、附件等信息全部合并。

第四步:恢复数据。

至此,所有数据已经合并成功。推荐用PHP MYADMIN或者MYSQLTOOL还原到目标论坛。

如何防止用户在论坛恶意灌水?

作者:唐文明

1:问:如果有注册机器人在Discuz!论坛上批量注册用户怎么办?

答:以管理员身份登入Discuz!后台,依次 “Discuz! 选项 -->安全控制--> 启用验证码”。将“新用户注册”选项前打勾,可有效防止注册机批量注册。

另外还可以设置注册限制:“Discuz! 选项-->注册与访问控制-->IP 注册间隔限制(小时) ”在这里设置同一台电脑注册时间的间隔也可有效防止恶意注册。

2:问:论坛如何防止论坛恶意批量发帖?

答:以管理员身份登入Discuz!后台,在后台设置防止灌水时间:“Discuz! 选项-->安全控制-->发帖灌水预防”,在这里设置两个帖子发表的时间间隔。

3:问:如何禁止论坛发表带有敏感字符的帖子?

答:以管理员身份登入Discuz!后台设置方法:依次进入后台 - 帖子相关 - 词语过滤 在 不良词语 输入框中填写要过滤的字符。在 替换为 输入框中填写改铭感字符过滤后的替换字符,如 需要过滤 “他妈的”为“TMD”则在 不良词语 输入框中填写 “他妈的”,在 替换为 输入框中填写“TMD”即可。有没有办法让含有某个字符的帖子无法发表呢?可以的。只要在上面选项中的 替换为 输入框中填写 “{BANNED}”,则将该铭感字符设置为不可发表。

4:问:如果发广告者在论坛各处发帖,管理员想一次性删除可以吗?

答:当然可以。以管理员身份登Discuz!后台,选择“论坛维护-->批量删帖”,在“发帖用户名”一项中填写恶意发帖者ID,点击提交后出现该ID所发表的所有文章,全部打勾或有选择性的批量删除即可。

用户怎样减少广告灌水机的骚扰

作者:叶天

问:我们的论坛用的是Discuz!,访问量很大,最近一直受到广告灌水机的骚扰。所以我想找到一个好的论坛广告管理机制,不知道有没有更好的解决方案?目前,我找到的解决方案似乎,用后台的管理功能,限制用户发帖时间,每隔一定时间(比如多少秒)才能发表一张帖。不过,这样的限制如果设置的时间大于5秒,也会妨碍了正常的用户访问,发广告的灌水工具来发根本没有影响,因为它是自动的。请问该怎么样解决?

答:关于广告灌水机的问题,我们都是深恶痛绝的。一般而言,广告的灌水工具(或发帖机器)现在都能内容相同但标题不同(添加特殊字符、随机串或多余空格的方式),因此,从论坛软件来说,根据内容对帖子限定是无效的。并且,采用这种机制,程序对数据库的压力极大,站长的硬件资源也将消耗很多。因此,Discuz!考虑到最终效果得不偿失,所以未予实施上述办法。

当然,Discuz!也不会放弃寻找更好的办法。目前,用户采用最新版本的Discuz!4.1,可以寻找的解决方案有两个:

一是采用发帖验证码;二是采用更长的灌水限制时间。

此外,Discuz!拟将在5.0中采用如下方案(www和wap上都要限制):

同一用户(假定不为游客)最近一小时(或一天)发帖数限制(标明影响效率)“maxppd(maxpostsperday)

if($discuz_uid) {SELECT COUNT(*) FROM cdb_posts WHERE dateline>'$timestamp'-86400 AND authorid='$discuz_uid'

}”

一般而言,这样应该可以更有效解决广告灌水的问题。

不过,考虑到Discuz!应用面的广泛,那些灌水机也一定不断寻找新的办法来骚扰。所以,我们需要更多的用户与我们一起去解决问题。

如何防止论坛恶意批量发帖?

1:问:如果有注册机器人在Discuz!论坛上批量注册用户怎么办?

答:以管理员身份登入Discuz!后台,依次 “Discuz! 选项 -->安全控制--> 启用验证码”。将“新用户注册”选项前打勾,可有效防止注册机批量注册。

另外还可以设置注册限制:“Discuz! 选项-->注册与访问控制-->IP 注册间隔限制(小时) ”在这里设置同一台电脑注册时间的间隔也可有效防止恶意注册。

2:问:论坛如何防止论坛恶意批量发帖?

答:以管理员身份登入Discuz!后台,在后台设置防止灌水时间:“Discuz! 选项-->安全控制-->发帖灌水预防”,在这里设置两个帖子发表的时间间隔。

3:问:如何禁止论坛发表带有敏感字符的帖子?

答:以管理员身份登入Discuz!后台设置方法:依次进入后台 - 帖子相关 - 词语过滤 在 不良词语 输入框中填写要过滤的字符。在 替换为 输入框中填写改铭感字符过滤后的替换字符,如 需要过滤 “他妈的”为“TMD”则在 不良词语 输入框中填写 “他妈的”,在 替换为 输入框中填写“TMD”即可。有没有办法让含有某个字符的帖子无法发表呢?可以的。只要在上面选项中的 替换为 输入框中填写 “{BANNED}”,则将该铭感字符设置为不可发表。

4:问:如果发广告者在论坛各处发帖,管理员想一次性删除可以吗?

答:当然可以。以管理员身份登Discuz!后台,选择“论坛维护-->批量删帖”,在“发帖用户名”一项中填写恶意发帖者ID,点击提交后出现该ID所发表的所有文章,全部打勾或有选择性的批量删除即可。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有