关闭DiscuzX3.5注册页面的注册邮箱验证
原文链接https://www.cnblogs.com/tangshiguang/p/6741136.html,原文作者:唐世光
原文中提到的方法在适用于X3.2-X3.4,但是X3.5中,如果不填邮箱的话提示邮箱无效
论坛官方去邮箱插件太贵了,本来就是给领导免费打工,给钱是不可能给的
于是DeepSeeek大法分析了下代码,现在把成品分享给大家
分析了原因是升级后校验代码块处于生成代码块的前面,导致永远到不了生成的位置
于是做出以下修改
打开source/class/class_member.php
定位到以下代码,大概533行左右
if(!$activationauth) {
$email = $email ? $email : $_GET['email'];
checkemail($email);
}
修改为
if(!$activationauth) {
$email = strtolower(trim($_GET['email']));
if(empty($email) && $_G['setting']['forgeemail']) {
$timestamp = date('YmdHis');
$_GET['email'] = $email = 'KB' . $timestamp . '@qq.com'; // 生成随机邮箱,生成邮箱以KB开头,@qq.com结尾
}
checkemail($email); // 在生成邮箱后校验
}
下面是原文的修改方法,先改完下面的部分,在改我上面提到的部分
discuzX3.2后台关闭注册邮箱必填选项的功能。详细过程如下:
步骤1:source/admincp/admincp_setting.php 文件
查找:
showsetting('setting_access_register_send_register_url', 'settingnew[sendregisterurl]', $setting['sendregisterurl'], 'radio');
大概是440-441行:
增加以下代码:
showsetting('setting_access_register_forge_email', 'settingnew[forgeemail]', $setting['forgeemail'], 'radio');
步骤2:打开source/language/lang_admincp.php 文件
查找: 一个邮箱只允许注册一个帐户
大概811行,增加以下代码:
'setting_access_register_forge_email' => '取消注册邮箱必填',
'setting_access_register_forge_email_comment' => '开启后如果用不不填写注册邮箱,将自动生成一个邮箱地址',
步骤3:修改source/class/class_member.php
大概611行:
原文是:
$email = strtolower(trim($_GET['email']));
if(empty($this->setting['ignorepassword'])) {
if($_GET['password'] !== $_GET['password2']) {
showmessage('profile_passwd_notmatch');
}
if(!$_GET['password'] || $_GET['password'] != addslashes($_GET['password'])) {
showmessage('profile_passwd_illegal');
}
$password = $_GET['password'];
} else {
$password = md5(random(10));
}
}
修改为(或直接替换以下:)(在原文随机码的基础上改为了KB+时间戳+@qq.com)
$email = strtolower(trim($_GET['email']));
if(empty($email) && $_G['setting']['forgeemail']) {
// 生成时间戳格式:年月日时分秒(例如 20250415120711)
$timestamp = date('YmdHis');
// 组合随机邮箱前缀码(KB)
$_GET['email'] = $email = 'KB' . $timestamp . '@qq.com';
}
if(empty($this->setting['ignorepassword'])) {
if($_GET['password'] !== $_GET['password2']) {
showmessage('profile_passwd_notmatch');
}
if(!$_GET['password'] || $_GET['password'] != addslashes($_GET['password'])) {
showmessage('profile_passwd_illegal');
}
$password = $_GET['password'];
} else {
$password = md5(random(10));
}
}