前言:
近日,博客经常被恶意注册,博客倒是没事,可是我邮箱炸了。。。日常20+邮件于是在网上找了一个加验证码的代码,分享给各位博主。 刚开始准备弄个高大上的化学方程式验证码(后期努力点,要不找一个要不自己写一个),可后来想想,要是用户化学不好就不能注册,那也太说不过去了。于是就找了这个10以内加法的验证码(这个要是不会就别注册了······)登陆页面验证码演示图:
登陆页面验证码使用说明:
登陆你的后台管理,选择【外观】-【编辑】-【模板函数 (functions.php)】直接添加下面全部代码:【?>前面】即可。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
//后台登陆数学验证码 function myplugin_add_login_fields() { //获取两个随机数, 范围0~9 $num1=rand(0,9); $num2=rand(0,9); //最终网页中的具体内容 echo "<p><label for='math' class='small'>验证码</label><br /> $num1 + $num2 = ?<input type='text' name='sum' class='input' value='' size='25' tabindex='4'>" ."<input type='hidden' name='num1' value='$num1'>" ."<input type='hidden' name='num2' value='$num2'></p>"; } add_action('login_form','myplugin_add_login_fields'); function login_val() { $sum=$_POST['sum'];//用户提交的计算结果 switch($sum){ //得到正确的计算结果则直接跳出 case $_POST['num1']+$_POST['num2']:break; //未填写结果时的错误讯息,可自定义修改 case null:wp_die('错误: 请输入验证码.');break; //计算错误时的错误讯息,可自定义修改 default:wp_die('错误: 验证码错误,请重试.'); } } add_action('login_form_login','login_val'); |
注册页面验证码演示图:
注册页面验证码使用说明:
登陆你的后台管理,选择【外观】-【编辑】-【模板函数 (functions.php)】直接添加下面全部代码:【?>前面】即可。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
//WordPress新用户注册随机数学验证码 function add_security_question_fields() { //获取两个随机数, 范围0~9 $num1=rand(0,9); $num2=rand(0,9); //最终网页中的具体内容 echo "<p><label for='math' class='small'>验证码:$num1 + $num2 = ? </label><input type='text' name='sum' class='input' value='' size='25'>" ."<input type='hidden' name='num1' value='$num1'>" ."<input type='hidden' name='num2' value='$num2'></p>";} add_action('register_form','add_security_question_fields'); add_action( 'register_post', 'add_security_question_validate', 10, 3 ); function add_security_question_validate( $sanitized_user_login, $user_email, $errors) { $sum=$_POST['sum'];//用户提交的计算结果 switch($sum){ //得到正确的计算结果则直接跳出 case $_POST['num1']+$_POST['num2']:break; //未填写结果时的错误讯息 case null:wp_die('错误:请输入验证码!');break; //计算错误时的错误讯息 default:wp_die('错误:验证码错误,请重试!');}} add_action( 'add_security_question','register_form' ); |
声明与备注:
- 部分代码转自拽立网,并非本人所写,在这里只是分享。
- 如需同时想让登陆页面与注册页面都添加数字验证,将以上2份代码全部加在functions.php即可
- 亲测验证码输错,不能注册,不能登陆。防机器注册很有效果,也不会影响用户体验
get了一个新技能
嗯哼
这非常有趣!
真方便,不知道是否能防恶意注册
可以的
登陆你的后台管理,选择【外观】–【编辑】–【模板函数 (functions.php)】直接添加下面全部代码:【?>前面】即可。
这个[?>前面]是在哪里呢?我在函数里面都找不到……
那就加到function末尾
Thanks
还有一个问题,添加到结尾后登陆没问题了,我也把注册的放在了登陆的那些代码后面,但是注册的时候没有验证码
慢慢调吧0.0
文中代码部分重复了两次,难道是重要的事情要说两次?
一个是注册页面的验证码,一个是登陆页面的验证码
看漏眼了,我还以为一样的,原来是自己看文章不够仔细,学习了