js登录滑动验证,不滑动无法登陆

js的判断这里是根据滑块的位置进行判断,应该是用一个flag判断

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%
    String basePath = request.getContextPath();
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>登录</title>

<link href="<%=basePath%>/res/css/bootstrap.min14ed.css?v=3.3.6"
    rel="stylesheet">
<link href="<%=basePath%>/res/css/font-awesome.min93e3.css?v=4.4.0"
    rel="stylesheet">

<link href="<%=basePath%>/res/css/animate.min.css" rel="stylesheet">
<link href="<%=basePath%>/res/css/style.min862f.css?v=4.1.0"
    rel="stylesheet">
<!--[if lt IE 9]>
    <meta http-equiv="refresh" content="0;ie.html" />
    <![endif]-->
<script>
    if (window.top !== window.self) {
        window.top.location = window.location;
    }
</script>
<style>
* {
    margin: 0;
    padding: 0;
}

body {
    font: 12px/1.125 Microsoft YaHei;
    background: #fff;
}

ul, li {
    list-style: none;
}

a {
    text-decoration: none;
}

.ani {
    transition: all .3s;
}

.wrap {
    width: 300px;
    height:;
    text-align: center;
    margin: 150px auto;
}

.inner {
    padding: 15px;
}

.clearfix {
    overflow: hidden;
    _zoom: 1;
}

.none {
    display: none;
}

#slider {
    position: relative;
    background-color: #e8e8e8;
    width: 300px;
    height: 34px;
    line-height: 34px;
    text-align: center;
}

#slider .handler {
    position: absolute;
    top: 0px;
    left: 0px;
    width: 40px;
    height: 32px;
    border: 1px solid #ccc;
    cursor: move;
}

.handler_bg {
    background: #fff
        url("")
        no-repeat center;
}

.handler_ok_bg {
    background: #fff
        url("")
        no-repeat center;
}

#slider .drag_bg {
    background-color: #7ac23c;
    height: 34px;
    width: 0px;
}

#slider .drag_text {
    position: absolute;
    top: 0px;
    width: 300px;
    -moz-user-select: none;
    -webkit-user-select: none;
    user-select: none;
    -o-user-select: none;
    -ms-user-select: none;
}

.unselect {
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
}

.slide_ok {
    color: #fff;
}
</style>
</head>
<style>
.btn-primary {
    background-color: #0000FF;
}

.btn-primary:hover {
    background-color: #0000FF;
}

.btn-primary {
    background-color: #0000FF;
    border-color: #0000FF;
}
</style>
<body class="gray-bg">

    <div class="middle-box text-center loginscreen  animated fadeInDown">
        <div>

            <h3 style="margin-top: 100px;">欢迎登录</h3>

            <form class="m-t" role="form" action="<%=basePath%>/login"
                method="POST" onsubmit="return login();">
                <div class="form-group">
                    <input name="username" id="username" type="text"
                        class="form-control" placeholder="用户名" required="">
                </div>
                <div class="form-group">
                    <input type="password" name="password" id="password"
                        class="form-control" placeholder="密码" required="">
                </div>
                
                <div class="wrap" style="margin: 10px auto 10px">
                    <div id="slider">
                        <div class="drag_bg"></div>
                        <div class="drag_text" onselectstart="return false;"
                            unselectable="on">拖动滑块验证</div>
                        <div class="handler handler_bg"></div>
                    </div>
                </div>
                <input type="hidden" name="${_csrf.parameterName}"
                    value="${_csrf.token}">
                <button type="submit" style="background-color: #0000FF;" class="btn btn-primary block full-width m-b">登
                    录</button>

                <%
                    if (request.getParameter("error") != null) {
                %>
                <span id="" style="color: red;">账号或者密码错误!</span>
                <%
                    }
                %>
                <%
                    if (request.getParameter("logout") != null) {
                %>
                <span>已经安全退出!</span>
                <%
                    }
                %>
                <p class="text-muted text-center">
                    <a href="login.html#"><small>忘记密码了?</small></a> | <a
                        href="<%=basePath%>/register">注册一个新账号</a>
                </p>

            </form>
        </div>
    </div>
    <script src="<%=basePath%>/res/js/jquery.min.js?v=2.1.4"></script>
    <script src="<%=basePath%>/res/js/bootstrap.min.js?v=3.3.6"></script>

</body>
<script type="text/javascript"
    src="<%=basePath%>/res/js/jquery-1.12.4.min.js"></script>
<script type="text/javascript" src="<%=basePath%>/res/js/jquery.md5.js"></script>
<script type="text/javascript">
    $(function() {
        $('#username').val();
    });

    function login() {
        if($(".drag_bg").width()<260){
            return false;
        }
        var password = $('#password').val();
        password = $.md5(password);
        console.log(password);
        $('#password').val(password);
        return true;
    }
</script>
<script>
    (function(window, document, undefined) {
        var dog = {//声明一个命名空间,或者称为对象
            $ : function(id) {
                return document.querySelector(id);
            },
            on : function(el, type, handler) {
                el.addEventListener(type, handler, false);
            },
            off : function(el, type, handler) {
                el.removeEventListener(type, handler, false);
            }
        };
        //封装一个滑块类
        function Slider() {
            var args = arguments[0];
            for ( var i in args) {
                this[i] = args[i]; //一种快捷的初始化配置
            }
            //直接进行函数初始化,表示生成实例对象就会执行初始化
            this.init();
}
Slider.prototype = {
            constructor : Slider,
            init : function() {
                this.getDom();
                this.dragBar(this.handler);
            },
            getDom : function() {
                this.slider = dog.$('#' + this.id);
                this.handler = dog.$('.handler');
                this.bg = dog.$('.drag_bg');
            },
            dragBar : function(handler) {
                var that = this, startX = 0, lastX = 0, doc = document, width = this.slider.offsetWidth, max = width
                        - handler.offsetWidth, drag = {
                    down : function(e) {
                        var e = e || window.event;
                        that.slider.classList.add('unselect');
                        startX = e.clientX - handler.offsetLeft;
                        console.log('startX: ' + startX + ' px');
                        dog.on(doc, 'mousemove', drag.move);
                        dog.on(doc, 'mouseup', drag.up);
                        return false;
                    },
                    move : function(e) {
                        var e = e || window.event;
                        lastX = e.clientX - startX;
                        lastX = Math.max(0, Math.min(max, lastX)); //这一步表示距离大于0小于max,巧妙写法
                        console.log('lastX: ' + lastX + ' px');
                        if (lastX >= max) {
                            handler.classList.add('handler_ok_bg');
                            that.slider.classList.add('slide_ok');
                            dog.off(handler, 'mousedown', drag.down);
                            drag.up();
                        }
                        that.bg.style.width = lastX + 'px';
                        handler.style.left = lastX + 'px';
                    },
                    up : function(e) {
                        var e = e || window.event;
                        that.slider.classList.remove('unselect');
                        if (lastX < width) {
                            that.bg.classList.add('ani');
                            handler.classList.add('ani');
                            that.bg.style.width = 0;
                            handler.style.left = 0;
                            setTimeout(function() {
                                that.bg.classList.remove('ani');
                                handler.classList.remove('ani');
                            }, 300);
                        }
                        dog.off(doc, 'mousemove', drag.move);
                        dog.off(doc, 'mouseup', drag.up);
                    }
                };
                dog.on(handler, 'mousedown', drag.down);
            }
        };
        window.S = window.Slider = Slider;
    })(window, document);
    var defaults = {
        id : 'slider'
    };
    new S(defaults);
</script>
</html>

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏跟着阿笨一起玩NET

DBHelper数据库操作类(一)

可以参考的:http://www.oschina.net/code/snippet_4946_748

611
来自专栏码匠的流水账

聊聊rocketmq的RequestTask

org/apache/rocketmq/remoting/netty/RequestTask.java

1262
来自专栏搞前端的李蚊子

Html5模拟通讯录人员排序(sen.js)

// JavaScript Document  var PY_Json_Str = ""; var PY_Str_1 = ""; var PY_Str_...

6326
来自专栏一个会写诗的程序员的博客

ClassMetadataReadingVisitor has interface org.springframework.asm.ClassVisitor as super class

ClassMetadataReadingVisitor has interface org.springframework.asm.ClassVisitor a...

975
来自专栏从零开始的linux

linux基础命令6

tr命令 # tr 'a-z' 'A-Z' < /etc/fstab # # /ETC/FSTAB # CREATED BY ANACONDA ON THU ...

2737
来自专栏菩提树下的杨过

Silverlight Telerik控件学习:TreeView数据绑定并初始化选中状态、PanelBar的Accordion效果、TabPanel、Frame基本使用

实际开发中控件的数据源肯定是动态绑定的,不可能在xaml里写死item项。既然要绑定,就先来几个实体类: ? 上面是类图,各类的代码如下:  Business...

2778
来自专栏码匠的流水账

聊聊ImageIO使用argb操作jpg的bug

本文主要来聊一下使用ImageIO在BufferedImage.TYPE_INT_ARGB默认下操作jpg格式图片显示黑色的bug。

1051
来自专栏CreateAMind

aws 上面最新最全的GPU深度学习镜像-避免手工安装各种各样的软件

Here we have a Deep Learning system image (AWS AMI) custom built for the p2.xlar...

962
来自专栏lgp20151222

RestTemplate的异常:Not enough variables available to expand

原因:RestTemplate使用出错,我的情况是不知道这里要求用RestTemplate的使用格式,应该很多人都是这样吧?不过,看了下RestTemplate...

804
来自专栏专知

2018年SCI期刊最新影响因子排行,最高244,人工智能TPAMI9.455

2018年6月26日,最新的SCI影响因子正式发布,涵盖1万2千篇期刊。CA-Cancer J Clin 依然拔得头筹,其影响因子今年再创新高,达244.585...

1462

扫码关注云+社区