1. 程式人生 > 程式設計 >JavaScript實現密碼強度實時驗證

JavaScript實現密碼強度實時驗證

JavaScript實現密碼強度實時驗證,供大家參考,具體內容如下

在網路服務中,為了保證使用者的私密資訊足夠安全,會要求使用者輸入具有一定安全級別的密碼,這樣可以更好的防止他人盜用。比如在註冊一些遊戲賬號時,如果輸入純數字或純英文字元低於6位,就會提示密碼強度太低,請重新輸入。一些密碼強度驗證的方法都是計算字元的型別,然後分類加權累算。權重越高,相應的強度也就越高。

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

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

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

 <script type="text/javascript">

  window.onload = function () {
   function setCss(_this,cssOption){
   //判斷節點型別
   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;

   /*字元權重;
   數字1,字母2,其他字元為3
   當密碼長度小於6時不符合標準
   長度>=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){//數字
      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>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。