java实现滑动验证解锁
作者:夏微凉秋微暖 发布时间:2023-06-02 12:16:36
标签:java,验证,解锁
本文实例为大家分享了java实现滑动验证解锁的具体代码,供大家参考,具体内容如下
1.html:
<div class="drag">
<div class="bg"></div>
<div class="text" onselectstart="return false;">请拖动滑块解锁</div>
<div class="dragBtn">>></div>
</div>
<script>
/* 滑动验证码 */
var successRand = '';
//一、定义一个获取DOM元素的方法
var
box = document.querySelector(".drag"),//容器
bg = document.querySelector(".bg"),//背景
text = document.querySelector(".text"),//文字
btn = document.querySelector(".dragBtn"),//滑块
success = false,//是否通过验证的标志
distance = box.offsetWidth - btn.offsetWidth;//滑动成功的宽度(距离)
//二、给滑块注册鼠标按下事件
btn.onmousedown = function(e){
//1.鼠标按下之前必须清除掉后面设置的过渡属性
btn.style.transition = "";
bg.style.transition ="";
//说明:clientX 事件属性会返回当事件被触发时,鼠标指针向对于浏览器页面(或客户区)的水平坐标。
//2.当滑块位于初始位置时,得到鼠标按下时的水平位置
var e = e || window.event;
var downX = e.clientX;
//三、给文档注册鼠标移动事件
document.onmousemove = function(e){
var e = e || window.event;
//1.获取鼠标移动后的水平位置
var moveX = e.clientX;
//2.得到鼠标水平位置的偏移量(鼠标移动时的位置 - 鼠标按下时的位置)
var offsetX = moveX - downX;
//3.在这里判断一下:鼠标水平移动的距离 与 滑动成功的距离 之间的关系
if( offsetX > distance){
offsetX = distance;//如果滑过了终点,就将它停留在终点位置
}else if( offsetX < 0){
offsetX = 0;//如果滑到了起点的左侧,就将它重置为起点位置
}
//4.根据鼠标移动的距离来动态设置滑块的偏移量和背景颜色的宽度
btn.style.left = offsetX + "px";
bg.style.width = offsetX + "px";
//如果鼠标的水平移动距离 = 滑动成功的宽度
if( offsetX == distance){
//1.设置滑动成功后的样式
text.innerHTML = "验证通过";
text.style.color = "#fff";
btn.innerHTML = "√";
btn.style.color = "green";
bg.style.backgroundColor = "lightgreen";
//2.设置滑动成功后的状态
success = true;
//成功后,清除掉鼠标按下事件和移动事件(因为移动时并不会涉及到鼠标松开事件)
btn.onmousedown = null;
document.onmousemove = null;
//3.成功解锁后的回调函数
setTimeout(function(){
successRand = new Date().getTime() + Math.random();
var obj = {};
obj.rand = successRand;
$.ajax({
type: "post",
url: projectName + "/loginC/setRand",
data: JSON.stringify(obj),
datatype: 'json',
contentType: "application/json",
success: function (data) {
//console.log(vm.parent.success);
//console.log(vm.isTest);
if (data.success == true) {
} else {
layer.alert(data.message);
// change_authimage();
}
},
error: function () {
layer.alert("请求失败");
}
});
},1);
}
}
//四、给文档注册鼠标松开事件
document.onmouseup = function(e){
//如果鼠标松开时,滑到了终点,则验证通过
if(success){
return;
}else{
//反之,则将滑块复位(设置了1s的属性过渡效果)
btn.style.left = 0;
bg.style.width = 0;
btn.style.transition = "left 1s ease";
bg.style.transition = "width 1s ease";
}
//只要鼠标松开了,说明此时不需要拖动滑块了,那么就清除鼠标移动和松开事件。
document.onmousemove = null;
document.onmouseup = null;
}
}
// 复位验证滑块
function restDragBtn() {
/*btn.style.left = 0;
bg.style.width = 0;
btn.style.transition = "left 1s ease";
bg.style.transition = "width 1s ease";
text.innerHTML = "请拖动滑块解锁";
btn.innerHTML = ">>>";
text.style.color = "#a9a9a9";*/
location.reload();
}
</script>
2.后端:
@RequestMapping(value="/setRand",method = RequestMethod.POST)
@ResponseBody
@ApiOperation(value = "设置验证码成功")
//@ApiImplicitParam(paramType = "query",name= "username" ,value = "用户名",dataType = "string")
/*public void userLogin(@RequestParam(value = "username" , required = false) String username,
@RequestParam(value = "password" , required = false) String password)*/
public Message setRand(@RequestBody JSONObject json,HttpServletRequest request){
Message message = new Message();
String rand = json.getString("rand");
if(StringUtils.isNotBlank(rand)){
// 将认证码存入redis
HttpSession httpSession = request.getSession();
redisUtil.set(httpSession.getId() + ".rand",rand);
redisUtil.expire(httpSession.getId() + ".rand",60);
message.setSuccess(true);
}else{
message.setMessage("发生异常,请刷新重试");
}
return message;
}
3.登录验证时:
// 验证验证码
String randInput = json.getString("rand");
String rand = (String) redisUtil.get(httpSession.getId() + ".rand");
if(randInput==null||!randInput.equals(rand)) {
message.setMessage("验证码验证失败");
// 清空验证码
redisUtil.set(httpSession.getId() + ".rand","");
return message;
}
来源:https://blog.csdn.net/pengbin790000/article/details/87811240


猜你喜欢
- 单例模式是最常用到的设计模式之一,熟悉设计模式的朋友对单例模式都不会陌生。一般介绍单例模式的书籍都会提到 饿汉式 和 懒汉式 这两种实现方式
- 得到选中项的value值并拼接成一个字符串返回public string GetChecked(CheckBoxList checkList
- •readonly和const都是用来标识常量的[1]。•const可用于修饰class的field或者一个局部变量(local varia
- Maven搭建springboot项目本文是基于Windows 10系统环境,使用Maven搭建springboot项目Windows 10
- 前言Webp是Google推出的一种新型图片格式,相比于 传统的PNG/JPG图片有着更小体积的优势,在Web中有着广泛的应用。由于Webp
- FileWriter/FileReader介绍:FileWriter 类从 OutputStreamWriter 类继承而来。该类按字符向流
- spring 容器依赖<dependency> <groupId>org.springframework
- stack介绍和使用stack文档介绍stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行元素的插
- ActiveMQ是什么ActiveMQ是消息队列技术,为解决高并发问题而生ActiveMQ生产者消费者模型(生产者和消费者可以跨平台、跨系统
- 本文为大家分享了C#利用VS中插件打包并发布winfrom程序,供大家参考,具体内容如下1.先在VS 的扩展更新中搜索此插件【2015 in
- 项目结构这个是在网上找的资源,出处记不得了,记录一下。程序的总体结构,很简单的:核心代码代码如下:ArrComparator.java类im
- 本文实例讲述了Java8新增的重复注解功能。分享给大家供大家参考,具体如下:一 点睛在Java 8以前,同一个程序元素前最多只能使用一个相同
- 本文实例为大家分享了java抓取邮箱号码的具体代码,供大家参考,具体内容如下java抓取文件中邮箱号码的具体代码package reg;im
- 有时我们可能会遇到下图这样一种情况 — 我们需要的资料或教程被分成了几部分存放在多个PDF文件中,不管是阅读还是保存都不是很方便,这时我们肯
- 请求映射源码首先看一张请求完整流转图(这里感谢博客园上这位大神的图,博客地址我忘记了):前台发送给后台的访问请求是如何找到对应的控制器映射并
- AutoCompleteTextView是实现动态匹配输入内容的一种输入框(EditText),如输入“and”时,会提示“Android”
- 一、template下文件不允许直接访问1、查资料得知:springboot项目默认是不允许直接访问template下的文件的,是受保护的。
- 异常是程序中的一些错误,但并不是所有的错误都是异常,并且错误有时候是可以避免的。比如说,你的代码少了一个分号,那么运行出来结果是提示是错误
- 方法一、使用系统控件ViewFlipper方式:布局文件:<ViewFlipper andro
- 本文项目为大家分享了Java实现 * 面五子棋的具体代码,供大家参考,具体内容如下项目介绍:本次设计是基于知识点Java类和对象以及数组开发的