论坛首页 Web前端技术论坛

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

浏览 3837 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2017-11-02  

最近公司老板要求做一个滑动拼图效果,搞了好久才搞定它;今天把它分享出来,大神勿喷!!!
演示效果参考: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/ 
};

 

论坛首页 Web前端技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics