亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

本文實(shí)例為大家分享了java實(shí)現(xiàn)滑動驗(yà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>
 /*    滑動驗(yàn)證碼    */
 var successRand = '';
 //一、定義一個(gè)獲取DOM元素的方法
 var
  box = document.querySelector(".drag"),//容器
  bg = document.querySelector(".bg"),//背景
  text = document.querySelector(".text"),//文字
  btn = document.querySelector(".dragBtn"),//滑塊
  success = false,//是否通過驗(yàn)證的標(biāo)志
  distance = box.offsetWidth - btn.offsetWidth;//滑動成功的寬度(距離)
 
 //二、給滑塊注冊鼠標(biāo)按下事件
 btn.onmousedown = function(e){
 
  //1.鼠標(biāo)按下之前必須清除掉后面設(shè)置的過渡屬性
  btn.style.transition = "";
  bg.style.transition ="";
 
  //說明:clientX 事件屬性會返回當(dāng)事件被觸發(fā)時(shí),鼠標(biāo)指針向?qū)τ跒g覽器頁面(或客戶區(qū))的水平坐標(biāo)。
 
  //2.當(dāng)滑塊位于初始位置時(shí),得到鼠標(biāo)按下時(shí)的水平位置
  var e = e || window.event;
  var downX = e.clientX;
 
  //三、給文檔注冊鼠標(biāo)移動事件
  document.onmousemove = function(e){
 
   var e = e || window.event;
   //1.獲取鼠標(biāo)移動后的水平位置
   var moveX = e.clientX;
 
   //2.得到鼠標(biāo)水平位置的偏移量(鼠標(biāo)移動時(shí)的位置 - 鼠標(biāo)按下時(shí)的位置)
   var offsetX = moveX - downX;
 
   //3.在這里判斷一下:鼠標(biāo)水平移動的距離 與 滑動成功的距離 之間的關(guān)系
   if( offsetX > distance){
    offsetX = distance;//如果滑過了終點(diǎn),就將它停留在終點(diǎn)位置
   }else if( offsetX < 0){
    offsetX = 0;//如果滑到了起點(diǎn)的左側(cè),就將它重置為起點(diǎn)位置
   }
 
   //4.根據(jù)鼠標(biāo)移動的距離來動態(tài)設(shè)置滑塊的偏移量和背景顏色的寬度
   btn.style.left = offsetX + "px";
   bg.style.width = offsetX + "px";
 
   //如果鼠標(biāo)的水平移動距離 = 滑動成功的寬度
   if( offsetX == distance){
 
    //1.設(shè)置滑動成功后的樣式
    text.innerHTML = "驗(yàn)證通過";
    text.style.color = "#fff";
    btn.innerHTML = "√";
    btn.style.color = "green";
    bg.style.backgroundColor = "lightgreen";
 
    //2.設(shè)置滑動成功后的狀態(tài)
    success = true;
    //成功后,清除掉鼠標(biāo)按下事件和移動事件(因?yàn)橐苿訒r(shí)并不會涉及到鼠標(biāo)松開事件)
    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);
   }
  }
 
  //四、給文檔注冊鼠標(biāo)松開事件
  document.onmouseup = function(e){
 
   //如果鼠標(biāo)松開時(shí),滑到了終點(diǎn),則驗(yàn)證通過
   if(success){
    return;
   }else{
    //反之,則將滑塊復(fù)位(設(shè)置了1s的屬性過渡效果)
    btn.style.left = 0;
    bg.style.width = 0;
    btn.style.transition = "left 1s ease";
    bg.style.transition = "width 1s ease";
   }
   //只要鼠標(biāo)松開了,說明此時(shí)不需要拖動滑塊了,那么就清除鼠標(biāo)移動和松開事件。
   document.onmousemove = null;
   document.onmouseup = null;
  }
 }
 
 // 復(fù)位驗(yàn)證滑塊
 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è)置驗(yàn)證碼成功")
 //@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)){
   // 將認(rèn)證碼存入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.登錄驗(yàn)證時(shí):

// 驗(yàn)證驗(yàn)證碼
 String randInput = json.getString("rand");
 String rand = (String) redisUtil.get(httpSession.getId() + ".rand");
 
    if(randInput==null||!randInput.equals(rand)) {
     message.setMessage("驗(yàn)證碼驗(yàn)證失敗");
     // 清空驗(yàn)證碼
     redisUtil.set(httpSession.getId() + ".rand","");
     return message;
 }

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

相關(guān)文章

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

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

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

    java中ArrayList與LinkedList對比詳情

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

    scala 讀取txt文件的方法示例

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

    Mybatis的mapper.xml中if標(biāo)簽test判斷的用法說明

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

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

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

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

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

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

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

    Java中字符編碼格式詳解

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

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

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

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

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

最新評論