飞流 发表于 2024-12-5 01:49:11

discuzX3.5修改用户名长度限制的方法

discuz3.5默认用户名长度限制是不小于 3 个字符,不超过15字符,数字和字母是占一个字符,中文站一般来说,中文用户名比较常见(至少我是这么觉得的),但是默认的限制就导致麦麦网注册时无法注册单中文ID了!
于是为了进一步提升麦麦网ID价值,我决定修改限制为不小于2字符即可注册,相当于默认可以注册单中文用户名!
下面公布代码修改教程
首先,改程序:
(其实就是搜索所有的len < 3)改成len < 2
/source/class/class_member.php
581行:
if($usernamelen < 2) {
                                        showmessage('profile_username_tooshort');
                                } elseif($usernamelen > 40) {
                                        showmessage('profile_username_toolong');
                                }
/source/plugin/wechat/wechat.class.php【这个是安装微信插件才会有的,一般不用改】
/source/module/forum/forum_ajax.php
/static/js/register.js
注意一下,这里还需要改282行的汉字提示。
/uc_client/model/user.php
/uc_server/model/user.php
修改语言包提示:
/source/language/lang_message.php
然后修改数据库的所有username字段。

注意:必须是所有的,否则在运行过程中会出现很多奇葩错误。
比如:注册后自动登陆是成功的,但是第二次登陆是失败的,提示密码错误等等。
网上教程大都说只改动pre_ucenter_member和pre_common_member表,这是错误的!

注意,要将表名前缀设置为自己自定义的表名前缀,默认为’pre_’。
温馨提示以及sql语句如下:
在phpmyadmin下执行sql语句:
ALTER TABLE pre_ucenter_admins MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_ucenter_feeds MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_ucenter_members MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_ucenter_mergemembers MODIFY username CHAR(40) NOT NULL;
ALTER TABLE pre_ucenter_protectedmembers MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_adminnote MODIFY admin VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_banned MODIFY admin VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_card_log MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_diy_data MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_failedlogin MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_grouppm MODIFY author VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_invite MODIFY fusername CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_member MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_member_validate MODIFY admin VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_member_verify_info MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_mytask MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_report MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_report MODIFY opname VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_session MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_common_word MODIFY admin VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_announcement MODIFY author VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_forumrecommend MODIFY author CHAR(40) NOT NULL;
ALTER TABLE pre_forum_groupuser MODIFY username CHAR(40) NOT NULL;
ALTER TABLE pre_forum_order MODIFY admin CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_pollvoter MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_promotion MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_post MODIFY author VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_postcomment MODIFY author VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_ratelog MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_rsscache MODIFY author CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_thread MODIFY author CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_threadmod MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_forum_trade MODIFY seller CHAR(40) NOT NULL;
ALTER TABLE pre_forum_tradecomment MODIFY rater CHAR(40) NOT NULL ;
ALTER TABLE pre_forum_tradelog MODIFY seller VARCHAR(40) NOT NULL ;
ALTER TABLE pre_forum_tradelog MODIFY buyer VARCHAR(40) NOT NULL ;
ALTER TABLE pre_forum_warning MODIFY operator CHAR(40) NOT NULL ;
ALTER TABLE pre_forum_warning MODIFY author CHAR(40) NOT NULL;
ALTER TABLE pre_home_album MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_blog MODIFY username CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_clickuser MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_comment MODIFY author VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_docomment MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_doing MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_feed MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_feed_app MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_friend MODIFY fusername VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_friend_request MODIFY fusername CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_notification MODIFY author VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_pic MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_poke MODIFY fromusername VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_share MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_show MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_specialuser MODIFY username VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_specialuser MODIFY opusername VARCHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_home_visitor MODIFY vusername CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_portal_rsscache MODIFY author CHAR(40) NOT NULL DEFAULT '';
ALTER TABLE pre_portal_topic_pic MODIFY username VARCHAR(40) NOT NULL DEFAULT '';

四哥 发表于 2024-12-14 13:52:23

情不知所起,一往而深,生者可以死,死者可以生,生而不可与死,死而不可复生者,皆非情之至也。—— 来自:麦麦社区(HUMAIMAI.COM)已读乱回

沃博 发表于 2024-12-18 20:18:50

生命如同寓言,其价值不在于长短,而在于内容。

吴广 发表于 2025-5-3 17:18:43

厉害厉害
页: [1]
查看完整版本: discuzX3.5修改用户名长度限制的方法