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

标签:java,验证,解锁
0
投稿

猜你喜欢

  • SpringBoot之如何指定配置文件启动

    2023-11-17 15:17:48
  • Spring @Bean注解的使用场景与案例实现

    2023-11-20 04:44:22
  • 详解Spring中bean的几种注入方式

    2023-02-12 20:25:07
  • java基于netty NIO的简单聊天室的实现

    2023-11-18 15:29:43
  • android自定义波浪加载动画的实现代码

    2021-11-03 12:25:59
  • C#采用mouse_event函数实现模拟鼠标功能

    2023-07-07 16:09:54
  • C#压缩或解压rar、zip文件方法实例

    2023-10-21 23:00:16
  • java操作excel表格详解

    2021-08-20 14:35:46
  • Android开发中的文件操作工具类FileUtil完整实例

    2021-07-04 23:24:41
  • redisson特性及优雅实现示例

    2022-02-13 19:51:25
  • 用C#将图片保存至Oracle BLOB字段中的方法

    2023-06-12 01:29:16
  • Java轻松掌握面向对象的三大特性封装与继承和多态

    2021-07-27 02:39:11
  • Java实现获取客户端真实IP方法小结

    2021-10-15 03:53:16
  • Intellij IDEA配置Jetty的方法示例

    2023-05-02 04:13:12
  • springboot用thymeleaf模板的paginate分页完整代码

    2023-10-21 05:06:05
  • 使用maven的profile构建不同环境配置的方法

    2023-08-30 23:43:45
  • SpringBoot获取配置文件内容的几种方式总结

    2023-11-24 18:10:48
  • Spring AOP源码深入分析

    2023-08-15 13:01:16
  • java实现上传图片并压缩图片大小功能

    2023-06-14 22:32:35
  • Android 虚拟按键与沉浸式的适配方法

    2021-11-27 22:03:02
  • asp之家 软件编程 m.aspxhome.com