欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java實現(xiàn)滑動驗證解鎖

 更新時間:2020年07月24日 10:30:17   作者:夏微涼秋微暖  
這篇文章主要為大家詳細介紹了java實現(xiàn)滑動驗證解鎖,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了java實現(xiàn)滑動驗證解鎖的具體代碼,供大家參考,具體內(nèi)容如下

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.鼠標按下之前必須清除掉后面設(shè)置的過渡屬性
  btn.style.transition = "";
  bg.style.transition ="";
 
  //說明:clientX 事件屬性會返回當事件被觸發(fā)時,鼠標指針向?qū)τ跒g覽器頁面(或客戶區(qū))的水平坐標。
 
  //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.在這里判斷一下:鼠標水平移動的距離 與 滑動成功的距離 之間的關(guān)系
   if( offsetX > distance){
    offsetX = distance;//如果滑過了終點,就將它停留在終點位置
   }else if( offsetX < 0){
    offsetX = 0;//如果滑到了起點的左側(cè),就將它重置為起點位置
   }
 
   //4.根據(jù)鼠標移動的距離來動態(tài)設(shè)置滑塊的偏移量和背景顏色的寬度
   btn.style.left = offsetX + "px";
   bg.style.width = offsetX + "px";
 
   //如果鼠標的水平移動距離 = 滑動成功的寬度
   if( offsetX == distance){
 
    //1.設(shè)置滑動成功后的樣式
    text.innerHTML = "驗證通過";
    text.style.color = "#fff";
    btn.innerHTML = "√";
    btn.style.color = "green";
    bg.style.backgroundColor = "lightgreen";
 
    //2.設(shè)置滑動成功后的狀態(tài)
    success = true;
    //成功后,清除掉鼠標按下事件和移動事件(因為移動時并不會涉及到鼠標松開事件)
    btn.onmousedown = null;
    document.onmousemove = null;
 
    //3.成功解鎖后的回調(diào)函數(shù)
    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{
    //反之,則將滑塊復位(設(shè)置了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 = "設(shè)置驗證碼成功")
 //@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("發(fā)生異常,請刷新重試");
  }
 
  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;
 }

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JAVA獲取HTTP請求頭的方法示例

    JAVA獲取HTTP請求頭的方法示例

    這篇文章主要介紹了JAVA獲取HTTP請求頭的方法,結(jié)合具體實例形式分析了java針對http請求頭的讀取及屬性操作技巧,需要的朋友可以參考下
    2017-06-06
  • java中ArrayList與LinkedList對比詳情

    java中ArrayList與LinkedList對比詳情

    這篇文章主要通過實例對Java中ArrayList與LinkedList進行了對比,需要的朋友可以參考下
    2017-04-04
  • scala 讀取txt文件的方法示例

    scala 讀取txt文件的方法示例

    這篇文章主要介紹了scala 讀取txt文件的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-06-06
  • Mybatis的mapper.xml中if標簽test判斷的用法說明

    Mybatis的mapper.xml中if標簽test判斷的用法說明

    這篇文章主要介紹了Mybatis的mapper.xml中if標簽test判斷的用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • java字符串格式化(String類format方法)

    java字符串格式化(String類format方法)

    這篇文章主要介紹了java字符串格式化(String類format方法),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • SpringBoot各種參數(shù)校驗的實例教程

    SpringBoot各種參數(shù)校驗的實例教程

    經(jīng)常需要提供接口與用戶交互(獲取數(shù)據(jù)、上傳數(shù)據(jù)等),由于這個過程需要用戶進行相關(guān)的操作,為了避免出現(xiàn)一些錯誤的數(shù)據(jù)等,一般需要對數(shù)據(jù)進行校驗,下面這篇文章主要給大家介紹了關(guān)于SpringBoot各種參數(shù)校驗的相關(guān)資料,需要的朋友可以參考下
    2022-03-03
  • Java中的StringTokenizer實現(xiàn)字符串切割詳解

    Java中的StringTokenizer實現(xiàn)字符串切割詳解

    這篇文章主要介紹了Java中的StringTokenizer實現(xiàn)字符串切割詳解,java.util工具包提供了字符串切割的工具類StringTokenizer,Spring等常見框架的字符串工具類(如Spring的StringUtils),需要的朋友可以參考下
    2024-01-01
  • Java中字符編碼格式詳解

    Java中字符編碼格式詳解

    在java應(yīng)用軟件中,會有多處涉及到字符集編碼,有些地方需要進行正確的設(shè)置,有些地方需要進行一定程度的處理。本文主要給大家講解java中字符的編碼格式等相關(guān)問題
    2016-03-03
  • Java中LocalCache本地緩存實現(xiàn)代碼

    Java中LocalCache本地緩存實現(xiàn)代碼

    本篇文章主要介紹了Java中LocalCache本地緩存實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • DynamicDataSource怎樣解決多數(shù)據(jù)源的事務(wù)問題

    DynamicDataSource怎樣解決多數(shù)據(jù)源的事務(wù)問題

    這篇文章主要介紹了DynamicDataSource怎樣解決多數(shù)據(jù)源的事務(wù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07

最新評論