PC手机端和嵌入式滑动拼图验证码三种效果
发布于 7 年前 作者 erdangjiade 4783 次浏览 最后一次编辑是 7 年前 来自 分享
粉丝福利 : 关注VUE中文社区公众号,回复视频领取粉丝福利

刚整合好的效果演示下载你可以参考下这里: http://www.erdangjiade.com/js/1141.html 效果图片如下: 完整代码如下:

首先要确认前端使用页面,比如登陆页面
<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.erdangjiade.com/

回到顶部