首页 > 开发 > PHP > 正文

PHP 极验验证码实例讲解

2024-05-04 22:52:17
字体:
来源:转载
供稿:网友

你能找到这篇文章,说明你对极验验证已经不是完全陌生的了,所有废话我就不多说了,直接开始表说如何使用它,不过在此之前呢,先粘贴几个你可能会用得到的网址:

官网:http://www.geetest.com/

官方文档:http://www.geetest.com/install/sections/idx-basic-introduction.html

github:https://github.com/GeeTeam/gt-php-sdk.git

如何使用:

首先要确认前端使用页面,比如登陆页面

<script src="http://code.jquery.com/jquery-1.12.3.min.js"></script>
<script src="http://static.geetest.com/static/tools/gt.js"></script>  

1.在登陆页面访问引入类库:

如果您的网站使用https,则只需要将引入极验库的地方换成https协议即可,不需要更改其它地方。例如更换成以下代码即可:

<script src="https://code.jquery.com/jquery-1.12.3.min.js"></script>
<script src="https://static.geetest.com/static/tools/gt.js"></script>  

2.初始化前端

下面的代码需要在页面加载后就执行,如果你使用jQuery,可以写在$(function(){});内

$.ajax({  // 获取id,challenge,success(是否启用failback)  url: "../web/StartCaptchaServlet.php?t=" + (new Date()).getTime(), // 加随机数防止缓存  type: "get",  dataType: "json",  success: function (data) {    // 使用initGeetest接口    // 参数1:配置参数    // 参数2:回调,回调的第一个参数验证码对象,之后可以使用它做appendTo之类的事件    initGeetest({      gt: data.gt,      challenge: data.challenge,      product: "popup", // 产品形式,包括:float,embed,popup。注意只对PC版验证码有效      offline: !data.success // 表示用户后台检测极验服务器是否宕机,与SDK配合,用户一般不需要关注    }, handlerPopup);  }});
  

上面代码的意思是说,页面加载后,需要到你指定的URL地址上获得验证码信息,至于上面的URL地址“../web/StartCaptchaServlet.php”里面写了什么内容,这个我们在服务器端代码部署会详细说明。

但是需要说明的是,上面的代码里有一个回调函数叫“handlerPopup”,这个函数是你需要验证码的真正初始化代码:如下:

// 代码详细说明var handlerPopup = function (captchaObj) {  // 注册提交按钮事件,比如在登陆页面的登陆按钮  $("#popup-submit").click(function () {    // 此处省略在登陆界面中,获取登陆数据的一些步骤        // 先校验是否点击了验证码    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("登陆错误!");        }      }    });  });  // 弹出式需要绑定触发验证码弹出按钮  // 比如在登陆页面,这个触发按钮就是登陆按钮  captchaObj.bindOn("#popup-submit");     // 将验证码加到id为captcha的元素里  // 验证码将会在下面指定的元素中显示出来  captchaObj.appendTo("#popup-captcha");     // 更多接口参考:http://www.geetest.com/install/sections/idx-client-sdk.html};              
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表