首页 > 编程 > JavaScript > 正文

JS实现PC手机端和嵌入式滑动拼图验证码三种效果

2019-11-19 17:34:12
字体:
来源:转载
供稿:网友

PC和手机端网站滑动拼图验证码效果源码,同时包涵了弹出式Demo,使用ajax形式提交二次验证码所需的验证结果值,嵌入式Demo,使用表单形式提交二次验证所需的验证结果值,移动端手动实现弹出式Demo三种效果

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

<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 };

以上所述是小编给大家介绍的JS实现PC手机端和嵌入式滑动拼图验证码三种效果.希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对武林网网站的支持!

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表