溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JavaScript實現(xiàn)密碼強度實時驗證的方法

發(fā)布時間:2021-04-12 09:42:04 來源:億速云 閱讀:158 作者:小新 欄目:web開發(fā)

小編給大家分享一下JavaScript實現(xiàn)密碼強度實時驗證的方法,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

在網(wǎng)絡(luò)服務(wù)中,為了保證用戶的私密信息足夠安全,會要求用戶輸入具有一定安全級別的密碼,這樣可以更好的防止他人盜用。比如在注冊一些游戲賬號時,如果輸入純數(shù)字或純英文字符低于6位,就會提示密碼強度太低,請重新輸入。一些密碼強度驗證的方法都是計算字符的類型,然后分類加權(quán)累算。權(quán)重越高,相應(yīng)的強度也就越高。

具體的寫法及實現(xiàn)方式有很多種,本文只介紹其中一種方案

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>密碼強度實時驗證</title>

</head>
<body>
 <h3>密碼強度實時驗證</h3>
 <input id="passwordStrength" data-hint='請輸入密碼' type="password" ><span id="showStrength"></span>

 <script type="text/javascript">

  window.onload = function () {
   function setCss(_this,cssOption){
   //判斷節(jié)點類型
   if (!_this || _this.nodeType ===3 || _this.nodeType === 8 ||!_this.style) {
    return;
   }
   for(var cs in cssOption){
    _this.style[cs] = cssOption[cs];
   }
   return _this;
  } 

  function trim(chars){
   return (chars ||"").replace(/^(\s|\u00a0)+|(\s|\u00a0)+$/g,"");
  }
  function passwordStrength(passwordStrength,showStrength){
   var self = this;

   /*字符權(quán)重;
   數(shù)字1,字母2,其他字符為3
   當(dāng)密碼長度小于6時不符合標(biāo)準(zhǔn)
   長度>=6,強度小于10,強度弱
   長度>=6,長度>=10且<15,強度中
   長度>=6,強度>=15,強*/
   passwordStrength.onkeyup = function(){
    var _color = ["red","yellow","orange","green"],
      msgs = ["密碼太短","弱","中","強"],
      _strength = 0,
      _v= trim(passwordStrength.value)
    _vL= _v.length,
      i=0;

    var charStrength = function(char){
     //計算單個字符強度
     if(char>=48 && char <=57){//數(shù)字
      return 1;
     }
     if(char>=97 && char<=122){//小寫
      return 2;
     }else{
      return 3; //特殊字符
     }
    }

    if(_vL<6){//計算模式
     showStrength.innerText = msgs[0];
     setCss(showStrength,{
      "color":_color[0]
     })
    }else{
     for(;i<_vL;i++){
      //遍歷字符
      _strength+=charStrength(_v.toLocaleLowerCase().charCodeAt(i));
     }
     if(_strength<10){
      //強度小于10
      showStrength.innerText = msgs[1];
      setCss(showStrength,{
       "color":_color[1]
      })
     }
     if(_strength>=10&&_strength<15){
      showStrength.innerText = msgs[2];
      setCss(showStrength,{
       "color":_color[2]
      })
     }
     if(_strength>=15){
      showStrength.innerText = msgs[3];
      setCss(showStrength,{
       "color":_color[3]
      })
     }
    }
   }
  }
  passwordStrength(
    document.getElementById("passwordStrength"),
    document.getElementById("showStrength"));

 };
 </script>
</body>
</html>

看完了這篇文章,相信你對“JavaScript實現(xiàn)密碼強度實時驗證的方法”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI