JavaScript

超轻量级php框架startmvc

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

更新时间:2020-04-23 02:15:01 作者:startmvc
PC和手机端网站滑动拼图验证码效果源码,同时包涵了弹出式Demo,使用ajax形式提交二次验

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手机端和嵌入式滑动拼图验证码三种效果.希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

js 滑动拼图验证码