WordPress自定义用户注册页面插件

如果您是想添加前台注册功能,可以参考:WordPress添加前台注册功能

如果您需要用户注册时填写手机号,可以用这个插件:Ludou Phone Register

如果你的WordPress开放后台注册的话,可能会遇到一个问题,那就是发送email的问题。用户注册时使用Email给他发送密码的目的是验证用户输入的Email的有效性,但是如果你的主机不支持发送Email,那么其他人就无法在你的WordPress站点注册。之前也有很多教程教你如何解决这个问题,解决方法是修改WordPress的源文件,让用户注册后直接给他显示密码,而不是给他发送Email,这样问题是解决了,但是每次WordPress升级后,又要重新修改,以现在WordPress的升级速度也够你受得了!

现在我写了一个WordPress插件,通过修改后台的注册表单,让用户注册时自行填写密码,不用去Email接收密码,管理员也不用担心WordPress升级后带来的影响,同时这个插件支持用户自行选择他需要注册的用户角色。具体演示见下图 :

WordPress后台注册表单

插件使用

下载插件压缩包,解压后上传至WordPress插件目录下,即/wp-content/plugins/,到WordPress后台激活插件Ludou Custom User Register即可,你的后台注册表单就已经像上图的一样了。该插件只针对WordPress单站点,开启多站点功能,本插件无效。

如果你想让用户注册成功后自动登录,并跳转到指定页面,可以参考这篇文章:WordPress用户注册成功后跳转到指定页面

本段内容针对1.0版本有效—>> 如果你是个”插件控”,总想将插件数量控制在一定范围内,但是又需要插件的功能,那就用文本编辑器打开ludou-custom-register.php,将里面的php代码全部复制到主题目录下的functions.php即可,实现的功能是完全一样的(现在你应该醒悟,那些所谓的 “免插件实现**功能” 以及 “纯代码实现**功能”,其实就是插件)。

这个插件支持用户注册时选择自己的角色,可选订阅者和投稿者,如果你不想让用户注册时选择身份,请用文本编辑器打开ludou-custom-register.php,搜索并删除以下代码:

<p>
	<label>用户身份:
		<select name="user_role" id="user_role">
			<option value="subscriber" <?php if($_POST['user_role'] == 'subscriber') echo 'selected="selected"';?>>订阅者</option>
			<option value="contributor" <?php if($_POST['user_role'] == 'contributor') echo 'selected="selected"';?>>投稿者</option>
		</select>
	</label>
</p>

再删除以下PHP代码:

if($_POST['user_role'] != 'contributor' && $_POST['user_role'] != 'subscriber')
    $errors->add('role_error', "<strong>错误</strong>:不存在的用户身份");$userdata['role'] = $_POST['user_role'];

2.0版本添加了验证码功能,增强了反恶意注册的功能。如果你不需要这个功能,可以用文本编辑器打开ludou-custom-register.php,删除以下代码:

<p>
	<label>验证码:<br />
		<input id="CAPTCHA" style="width:110px;*float:left;" class="input" type="text" tabindex="24" size="10" value="" name="captcha_code" />
		看不清?<a href="javascript:void(0)" onclick="document.getElementById('captcha_img').src='<?php echo constant("LCR_PLUGIN_URL"); ?>/captcha/captcha.php?'+Math.random();document.getElementById('CAPTCHA').focus();return false;">点击更换</a>
	</label>
</p>

以及以下代码:

	if(empty($_POST['captcha_code'])
		|| empty($_SESSION['ludou_lcr_secretword'])
		|| (trim(strtolower($_POST['captcha_code'])) != $_SESSION['ludou_lcr_secretword'])
		) {
		$errors->add('captcha_spam', "<strong>错误</strong>:验证码不正确");
	}
	unset($_SESSION['ludou_lcr_secretword']);

同时删除整个captcha文件夹。

如果出现,点击注册后等待很长时间没反应,最后出现504错误,可以检查一下主机的邮件功能是否可以正常使用,具体见:韩世麟网友的留言。

2.0以后版本可以参考2.0版的代码进行修改或删除。

更新记录

1.0版本 2011年03月25日
* 首个版本

2.0版本 2011年04月25日
* 去除注册后首次登陆,要求修改默认密码的提示
* 添加验证码功能,增强防恶意注册能力
* 改进了部分HTML代码

2.0.1版本 2011年05月24日
* 改进了部分HTML和PHP代码
* 添加了部分代码注释

2.0.3版本 2012年09月22日
* 2.0.1版不带验证码和选择用户角色的版本,没有验证码同样可以防恶意注册功能
* 第90行代码中的60,为前后两次注册的时间间隔秒数,用于防恶意注册,可酌情修改

2.1.1版本 2013年01月27日
* 2.0.1版基础上增加了用户注册时,须填写昵称的功能
* 验证码改为5-6位的随机字母,改善用户体验

3.0版本 2015年12月29日
* WordPress 4.4中,解决中文用户名注册成功后,数据库users表中user_nicename一栏为空的问题

== 2017年4月5日 ==
* 所有版本均已去除 “密码将通过电子邮件发送给您” 和 “注册成功!请查收邮件” 字样,避免对注册用户的误导!

== 2017年9月16日 ==
* 所有版本添加了防CSRF跨站攻击代码

插件下载

— 完 —

评论0

请先

没有账号? 忘记密码?
'); })();