论坛升级后发现注册用户在输入任何邮箱email时,一直提示email 地址无效.用firephp跟踪发现:随机生成的email的后缀是@localhost!

找到原因,修改如下:

//原来代码
if(empty($email) && $_G['setting']['forgeemail'])
{
$_GET['email'] = $email = strtolower(random(6)).'@'.$_SERVER['HTTP_HOST'];
}
//但是如果本地调试emai后缀就是@localhost,不符合邮箱的规则
if(empty($email) && $_G['setting']['forgeemail'])
{
$_GET['email'] = $email = strtolower(random(16)).'@'.'klaus.com';
}
//增加了16位随机码,减少生成相同的邮箱概率;
//后缀固定,这样就不提示'Email 地址无效'了!

但是这个感觉太lower了,回到dz3.1以前的玩法是:

在DZ3.2以前的版本的后台我们可以在全局——注册与访问——取消邮箱注册必填如下图:

接下来就问题来了,Discuz官方团队可能也考虑到了这个问题,也许他们也像我这样认为这个地方在后台出现没多大必要,于是他们就在X3.2版本中更新了这个模块,更新的结果我觉得应该是这样的:在后台取消这个设置,但数据库里面存储的信息不变,而且在注册的时候不再使用这个数据库里面的设置的值为依据。于是就造成了上面的问题了,虽然让用户觉得不需要必须填(因为没红星),但不填之后注册不了

问题分析

通过对X3.1后台设置分析发现这里是一个radio类型的,也就是开关(废话而已,谁都看得出来);表单name为settingnew[forgeemail],值为0和1,0为关闭,1为打开,这个跟一般的习惯都是一样的。也就是说这个值选择1时我们注册的时候可以不需要填写邮箱,反之也就是默认情况下我们必须填写邮箱才能注册帐号。

而做过Discuz二次开发的同学都应该清楚,其实后台类似这样的设置数据都是存储在common_setting这个数据表中,而很快我发现这个数据表中直接有forgeemail这个记录,说明这个地方dz是直接保存的(不想保存高亮值信息那样,还通过进制转化,哈哈,不用再看源代码去了)。如下图(当然下面是默认的样子)

问题解决

说到这里大家就应该明白了什么问题了,其实这个问题就是3.2以后这个数据表中的skey为forgeemail的记录只是用于判断是否带红星,而不用于判断是不是真要填;换句话说不管这里设置的是0还是1,你的网站注册的时候都得填写邮箱(这可能也是DZ团队在升级改变这个问题所忽视的地方,比如就算强制设计成必填,那么也应该把数据库的这个字段值在升级的时候自动覆盖成0了)。

那么如果彻底解决(也就是可以让你的网站实现用户不不必填写邮箱也可以注册),这个相对比较复杂,要修改你注册表单的验证程序,而且我个人也不推荐这么做,这里就不详述了。

那么接下来就是把注册的时候带上红星(其实默认的时候就是这样的),当然问题是针对在3.2之前通过后台设置过这值的网站。那么现在去数据库找到common_setting这个数据表找到skey值forgeemail的svalue改为默认的0就可以了,也可以在数据库管理工具或者网站后台运行以下sql语句

update pre_common_setting set 'svalue'='0' where  'skey'='orgeemail'
注意:这里的表前缀为DZ的默认的pre_,如果你修改了,改成你新修改的

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));
}
}

修改为(或直接替换以下:)

$email = strtolower(trim($_GET['email']));
if(empty($email) && $_G['setting']['forgeemail']) {
$_GET['email'] = $email = strtolower(random(6)).'@'.$_SERVER['HTTP_HOST'];
} 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));
}
}

工具->更新缓存:
全局->注册与访问控制:

如果你想在注册页面不显示 注册邮箱选项,直接去掉模板中的相应的email代码即可。

关闭discuzX3.2注册页面的注册邮箱验证的更多相关文章

  1. Ecshop实现注册页面手机号唯一的验证

    前天,公司总监提了一个需求,实现我公司商城注册会员用手机号登录这个功能,那么这个功能容易修改,在我的前一篇博文中已经给出处理方法了,但是这里有一个问题,就是如果实现了用手机号码来登陆,那么就需要在注册 ...

  2. 实现Ecshop注册页面手机号唯一的验证

    如果Ecshop实现了用手机号码来登陆,那么就需要在注册时保证会员所填写的手机号是唯一的,也就是说手机号还未被注册,那么该怎么来检测填写的手机号是否注册过了呢? 一.参考ecshop检测邮箱 因为注册 ...

  3. localStorage注册页面A注册数据在本地储存并在B页面打开

    如题目的这么一个问题, A页面代码 <!DOCTYPE html> <html lang="en"> <head> <meta chars ...

  4. iOS BMOB-登录注册手机验证码、邮箱验证

    1.下载BmobSDK 2.把里面的BmobSDK.framework拖到你的工程里面的工具文件夹内. 3.导入类库 CoreLocation.framework.Security.framework ...

  5. JavaWeb网上图书商城完整项目--27.注册页面之注册按钮图片切换实现

    我们要实现立即注册这个按钮,光标获得焦点是一张图片,光标失去焦点的时候是另外一张图片 我们需要在文档加载完成之后,设置该事件hover事件 hover(over,out)这是jQuery的一个模仿悬停 ...

  6. DEDECMS开启邮箱验证通知的解决方法

    [摘要]织梦CMS是开源内容管理系统,是国内开源CMS的领先品牌,目前程序安装量已达七十万,本文介绍DEDECMS会员注册时,开启邮箱验证通知的解决方法. 在论坛上看到很多人都说这个功能没用,邮箱根本 ...

  7. DW课堂练习 用所学的知识去制作一个 (邮箱的注册页面)

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. 短信登录与注册接口、前端所有方式登录注册页面、redis数据库介绍与安装

    今日内容概要 短信登陆接口 短信注册接口 登陆注册前端 redis介绍和安装 内容详细 1.短信登陆接口 在视图类 user/views.py中修改并添加: from .serializer impo ...

  9. 注册页面的简单搭建(H5)

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

随机推荐

  1. 如何垂直居中<img>?

    方法1: 父元素设置height=line-height,子元素设置vertical-align:middle; 方法2: 父元素display:table-cell;vertical-align:m ...

  2. Dev使用技巧

    1.  dev调试 I.建工程,选择console application II.设置断点(F4),并按F5,(完成输入后,)其它功能如Next line可运作 2.  修改字体大小:Tools-&g ...

  3. php与mysql之间操作原理

    php和mysql相关扩展有:mysql.mysqli和pdo三种 mysql扩展从php5.5.0被废弃,并且从从php7.0.0开始被废除 mysql之前的使用---几个基本的函数:mysql_c ...

  4. 在.NET项目中使用PostSharp,实现AOP面向切面编程处理

    PostSharp是一种Aspect Oriented Programming 面向切面(或面向方面)的组件框架,适用在.NET开发中,本篇主要介绍Postsharp在.NET开发中的相关知识,以及一 ...

  5. Java数据结构之Set学习总结

    前言: 前面介绍了Java的数据结构List.Map,今天抽空学习总结一下另一种数据结构Set. Set介绍 Set相对于List.Map是最简单的一种集合.集合中的对象不按特定的方式排序,并且没有重 ...

  6. [lua] 你所不知道的lua nil值在可变参数函数中怎么处理!

    在lua中, 问题1:如果你在可变参数...中传入若干个参数,其中有的参数要带nil,这时怎么解决呢?(比如local function _test(...) end    _test(1, nil, ...

  7. redux三个基本原则

    (1)单一数据源:整个应用的state被存储在一棵object tree中,并且这个object tree只存在于唯一一个store中: (2)state是只读的:唯一改变state的方法就是触发ac ...

  8. CAS进行https到http的改造方案,结合cookie源码分析

    先说具体的改造方案: 服务端: 一.CAS Server端的修改 1.找到cas\WEB-INF\deployerConfigContext.xml 对以下Bean增加参数p:requireSecur ...

  9. eclipse中以debug方式启动tomcat报错

    在eclipse中debug  Tomcat报错,错误如下: FATAL ERROR in native method: JDWP No transports initialized, jvmtiEr ...

  10. ICC_lab总结——ICC_lab1:数据设置和基本流程

    ICC_lab总结 最近在学习后端的流程,做lab是最好不过了.但是有时候做过了lab,过了一段时间之后就会忘记,因此需要自己总结一下,加强印象. ICC_lab1:数据设置和基本流程 数据设置: 一 ...