PHP 极验验证码实例讲解
|
你能找到这篇文章,说明你对极验验证已经不是完全陌生的了,所有废话我就不多说了,直接开始表说如何使用它,不过在此之前呢,先粘贴几个你可能会用得到的网址: 官网: 官方文档: github: 如何使用:首先要确认前端使用页面,比如登陆页面
1.在登陆页面访问引入类库:如果您的网站使用https,则只需要将引入极验库的地方换成https协议即可,不需要更改其它地方。例如更换成以下代码即可:
2.初始化前端下面的代码需要在页面加载后就执行,如果你使用jQuery,可以写在$(function(){});内 上面代码的意思是说,页面加载后,需要到你指定的URL地址上获得验证码信息,至于上面的URL地址“../web/StartCaptchaServlet.php”里面写了什么内容,这个我们在服务器端代码部署会详细说明。 但是需要说明的是,上面的代码里有一个回调函数叫“handlerPopup”,这个函数是你需要验证码的真正初始化代码:如下: // 先校验是否点击了验证码
var validate = captchaObj.getValidate();
if (!validate) {
alert('请先完成验证!');
return;
}
// 提交验证码信息,比如登陆页面,你需要提交登陆信息,用户名和密码等登陆数据
$.ajax({
url: "../web/VerifyLoginServlet.php",type: "post",// dataType: "json",data: {
// 用户名和密码等其他数据,自己获取,不做演示
username:username,password:password,// 验证码数据,这些数据不用自己获取
// 这是二次验证所需的三个值
// 当然,你也可以直接设置验证码单独校验,省略其他信息
geetest_challenge: validate.geetest_challenge,geetest_validate: validate.geetest_validate,geetest_seccode: validate.geetest_seccode
},// 这里是正确返回处理结果的处理函数
// 假设你就返回了1,2,3
// 当然,正常情况是返回JSON数据
success: function (result) {
// 1表示验证码验证失败
if (result == "1") {
alert("验证码验证失败!");
}else if (result == "2") {
alert("用户名或密码错误!");
}else if (result == "3") {
alert("登陆成功!");
// 登陆成功了,可以在这里做其他处理
}else{
alert("登陆错误!");
}
}
});
}); // 将验证码加到id为captcha的元素里 // 更多接口参考:http://www.geetest.com/install/sections/idx-client-sdk.html 至此,前端的所有设置都写完了,官方的说明文档:http://www.geetest.com/install/sections/idx-client-sdk.html 3.服务器端部署(PHP)在第一步中,我们设置了一个这样的地址“../web/StartCaptchaServlet.php”,在这个地址里边写什么呢: // 生成验证码信息,并返回给客户端 $status = $GtSdk->pre_process($user_id); $_SESSION['gtserver'] = $status; $_SESSION['user_id'] = $user_id; echo $GtSdk->get_response_str(); ?> 如何获取 验证ID 和 验证Key : 1.从 验证后台 注册账号 2.添加验证,可以获取一组当前验证的ID/Key 3.将ID和Key分别替换到config.php文件中的captcha_id/private_key变量的值 4.点击提交按钮之后的服务端校验(二次验证)比如上面说的,用户登录时,你把用户名和密码和验证码信息都提交到服务器了,这个时候,你就可以做校验了: // 比如你设置了一个验证码是否验证通过的标识 $code_flag=false; // 这里获取你之前设置的user_id,传送给极验服务器做校验 // 如果验证码验证成功,再进行其他校验 感谢你的阅读,希望能帮助到大家,谢谢大家对本站的支持! (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
