最新赞助活动温馨提示:自愿赞助服务器费用,学生和没有工作的整站资源免费下载!
头像

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

来源:http://www.erdangjiade.com/js/1141.html 沐浴春风 2016-08-06 07:40浏览(10199)

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

0、请不要问“在不在”之类的问题,有问题直接问!1、学生或暂时没有工作的童鞋,整站资源免费下载!2、¥9.9充值终身VIP会员,加我微信,826096331 拉你进VIP群学习!3、程序员加油,技术改变世界。在线 充值

PC手机端和嵌入式滑动拼图验证码三种效果
分类:表单代码 > 验证码 难易:中级
查看演示

加我微信,拉你进VIP群学习:

下载资源 下载积分: 100 积分

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

<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/
};
声明:本文为原创文章,如需转载,请注明来源erdangjiade.com并保留原文链接:https://www.erdangjiade.com/js/1141.html
评论131
头像

友情提示:垃圾评论一律封号 加我微信:826096331拉你进VIP群学习群

  • 头像 130楼
    01-02 10:19
    smz1314
    货不对,太过分
  • 头像 129楼
    01-01 16:12
    smz1314
    货不对,太过分了
  • 头像 128楼
    04-22 18:13
    Apollo
    货不对版,太过分了
  • 头像 127楼
    04-22 17:29
    Apollo
    跟演示的不一样,货不对板中指
  • 头像 126楼
    04-22 17:15
    Apollo
    不够积分呀,啊啊啊啊啊啊啊
  • 头像 125楼
    04-10 08:49
    luojie972
    获取积分
  • 头像 124楼
    09-15 09:28
    希望没问题
    是不是密匙过期了<br />
  • 头像 123楼
    09-13 19:04
    yango
    有人下了吗?有用吗。demo演示不了
  • 头像 122楼
    08-24 18:02
    workcss
    我看看,我需要这个插件啊
  • 头像 121楼
    08-20 17:56
    jz123
    找了好久的插件。。。
1 2