让代码更简单

当前位置:代码狗 > WordPress > WP建站 > 正文

给你的网站添加腾讯免费验证码功能

重要:本文最后更新于2021-01-12 20:10:23,某些文章具有时效性,若有错误或已失效,请在下方留言或联系代码狗

自从腾讯给每个人提供了20000次免费验证码后,成功吸引到了一波白嫖站长,由于这2W验证码有效期只有一年,为了不浪费赶紧利用起来才是王道。下面一起来学习下腾讯验证码是如何使用的。

腾讯云验证码地址:https://cloud.tencent.com/product/captcha

没开通的自己去上面的地址开通免费验证码,在控制台图形验证码里面点免费资源包,即可领取2W码。

开通好了后我们就要写代码了,第一步引入腾讯验证码js类。

<script src="https://ssl.captcha.qq.com/TCaptcha.js"></script>

如果你嫌弃腾讯的速度慢,可以将其下载到你的服务器中。

然后开始使用验证码功能。

一、标签属性绑定

在需要激活验证码的 DOM 元素(button、div、span)内加入以下 ID 及属性。

<!--点击此元素会自动激活验证码-->
<!--id : 元素的 ID(必须)-->
<!--data-appid : 验证码AppID(必须)-->
<!--data-cbfn : 回调函数名(必须)-->
<!--data-biz-state : 业务自定义透传参数(可选)-->
<button id="TencentCaptcha"
data-appid="appId"
data-cbfn="callback"
type="button"
>验证</button>

创建js回调函数

window.callback = function(res){
console.log(res)
// res(用户主动关闭验证码)= {ret: 2, ticket: null}
// res(验证成功) = {ret: 0, ticket: "String", randstr: "String"}
if(res.ret === 0){
alert(res.ticket) // 票据
}
}

注意:该JS验证码类会自动绑定id名为TencentCaptcha的HTML标签,如果不想使用它,请避免使用此id。

二、JS绑定HTML元素

手动绑定不要使用id="TencentCaptcha"的元素,避免重复绑定单击。

//方法1: 直接生成一个验证码对象。
var captcha1 = new TencentCaptcha('appId', function(res) {/* callback */});
captcha1.show(); // 显示验证码

//方法2:绑定一个元素并自动识别场景id和回调。
// 验证码会读取dom上的`data-appid`和`data-cbfn`以及`data-biz-state`(可选)自动初始化
new TencentCaptcha(document.getElementById('TencentCaptchaBtn'));

//方法3:绑定一个元素并手动传入场景Id和回调。
new TencentCaptcha(
document.getElementById('TencentCaptchaBtn'),
'appId',
function(res) {/* callback */},
{ bizState: '自定义透传参数' }
);

回调内容

前端验证成功后,验证码会调用业务传入的回调函数,并在第一个参数中传入回调结果。结果字段说明如下:

字段名 值类型 说明
ret Int 验证结果,0:验证成功。2:用户主动关闭验证码。
ticket String 验证成功的票据,当且仅当 ret = 0 时 ticket 有值。
appid String 场景 ID。
bizState Any 自定义透传参数。
randstr String 本次验证的随机串,请求后台接口时需带上。

更多详细参数请查阅腾讯在线文档:https://cloud.tencent.com/document/product/1110/36841

使用DMD主题的用户,可以参考如下写法。

首先在function-theme.php文件中找到_the_head函数,这里是控制输出网页头部一些资源的,在其中加上腾讯的验证码js,就是上面那个。如果你不想每个页面都加载,只在特定页面加载可以使用wordpress的判断函数自行判断。

然后在pages目录下找到login.php文件,找到最后面的一段js,将之改为:

<script>
var captcha1 = new TencentCaptcha('XXX你的appid', function(res) {
if(res.ret==0){
$.ajax({
url: '/wp-content/themes/dmd/action/user.php',
type: 'POST',
dataType: 'json',
data: $('.sign-form').serializeObject(),
success: function(data, textStatus, xhr) {
$(".sign-tips").text(data.msg);
$(".sign-tips").css("display","block");
setTimeout(function () {
$(".sign-tips").css("display","none");
}, 6000);
if (data.error){ 
}else{
window.location.href=data.back;
} 
}
});
}
});
function loginjs(frm,event){
var event=window.event?window.event:event; 
if(event.keyCode==13){
captcha1.show();
}
}
$(function(){
$('.btn-block').on('click', function(e){
captcha1.show();
});
});
</script>

此时再登录就会先触发验证码,当正确验证后才会向服务器发起登录请求。当然,这样只是对前端进行了验证,用户的验证数据是不是有效的、可靠的还需要传递给腾讯的验证码服务器验证,其中需要涉及到PHP的api这里由于篇幅问题就先不讲了,下一篇再讲。

具体效果如我演示站的登录页。DMD主题演示站登录页

感觉很棒!可以赞赏支持我哟~

赞(1) 打赏
感谢 1人打赏10元

评论 4

  1. #2

    嗯嗯,可惜只有免费2W码!

    万花网2周前 (01-08)回复
  2. #1

    你特么不能把你的dmd内置一下吗?

    缙哥哥2周前 (01-05)回复
    • 下次升级添加

      代码狗2周前 (01-05)回复
      • 嘎嘎~

        moi2周前 (01-06)
×

请作者吃根烤肠!

支付宝