discuzX3.4增加用户名注册和登录长度限制(终极版,实测有效,附带详细数据库修改策略)

11 篇文章 0 订阅

最近有需要改dz X3.4的用户名注册策略,由于用户名当中有后缀要求,实际位数达到将近40位,所以需要将用户名修改。
网上有很多修改程序的半吊子教程,用户注册成功后只能当时登录,退出之后就无法登录了,提示用户名或密码错误。所以想了想,还是写个完全版的教程,给大家伸手党的快感


首先,改程序:
(其实就是搜索所有的len > 15)改成len > 40

/source/class/class_member.php
579行:

if($usernamelen < 3) {
					showmessage('profile_username_tooshort');
				} elseif($usernamelen > 40) {
					showmessage('profile_username_toolong');
				}

/source/module/forum/forum_ajax.php
在这里插入图片描述
/source/plugin/wechat/wechat.class.php【这个是安装微信插件才会有的,一般不用改
在这里插入图片描述
/static/js/register.js
注意一下,这里还需要改282行的汉字提示。
在这里插入图片描述
/uc_client/model/user.php
在这里插入图片描述
/uc_server/model/user.php
在这里插入图片描述

修改语言包提示:
/source/language/lang_message.php

'reg_username' => '用户名必须为大于3位小于40位',
'registerinputtip' => '用户名:3-40位',

/template/default/member/register.htm
搜索

maxlength="15"

改为maxlength=“40


然后修改数据库的所有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 '';


之后要检测自己插件里面的表,(一般不会有用户名设置等问题),更改里面的username字段。

同时:有一个重要提示,用户名要求较长的,通常邮箱账号也会很长,要注意记得更改邮箱账号数据库长度!

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值