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

javascrpt密碼強(qiáng)度校驗(yàn)函數(shù)詳解

 更新時(shí)間:2020年03月18日 16:21:27   作者:白天的貓頭鷹  
這篇文章主要為大家詳細(xì)介紹了javascrpt密碼強(qiáng)度校驗(yàn)函數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

最近寫(xiě)了個(gè)密碼強(qiáng)度驗(yàn)證的函數(shù),主要驗(yàn)證以下內(nèi)容

1、密碼最小和最大長(zhǎng)度

2、連續(xù)字符串出現(xiàn)的次數(shù)

3、字符連續(xù)出現(xiàn)的次數(shù)

4、禁止特定的字符串作為密碼

5、密碼字符串的組合強(qiáng)度要求,必須含有大小寫(xiě)字母,必須含有數(shù)字,必須含有特殊字符

6、輸入密碼必須與確認(rèn)密碼一致

7、支持禁止使用用戶名作為密碼

8、是否存在連續(xù)性的字符串,是否存在逆序性的字符串

(function(window, verifyPwd){
  window.verifyPwd = {
    /*最小長(zhǎng)度*/
    minLength  : 6
 
    /*最大長(zhǎng)度*/
    maxLength  : 18,
 
    /*字符重復(fù)次數(shù)*/
    repeatCount : 0,
 
    /*連續(xù)字符*/
    seriesCount : 3,
 
    /*特定過(guò)濾字符串*/
    filter   : [
      "qaz",
      "wsx",
      "edc",
      "qwe",
      "asd",
      "zxc"
    ],
 
    /*允許的字符串*/
    arrRegex : ['[0-9]', '[a-z]', '[A-Z]', '[!@#$%^&*()_-]' ],
 
    /**
     * 驗(yàn)證密碼
     * @param userName   用戶名
     * @param pwd      密碼
     * @param confirmPwd  確認(rèn)密碼
     * @returns {boolean}
     */
    verify : function(userName, pwd, confirmPwd){
      userName = trim(userName);
      pwd   = trim(pwd);
 
      if(!userName || userName.length == 0){
        alert('請(qǐng)先輸入用戶名');
 
        return false;
      }
 
      if(!pwd || pwd.length == 0){
        alert('請(qǐng)輸入密碼');
 
        return false;
      }
 
      if (pwd.length < this.minLength) {
        alert('密碼長(zhǎng)度至少需要' + this.minLength + '位');
 
        return false;
      }
 
      if (pwd.length > this.maxLength) {
        alert('密碼長(zhǎng)度超過(guò)'+ this.maxLength +'位');
        return false;
      }
 
      /*判斷輸入密碼與確認(rèn)密碼是否一致*/
      if(confirmPwd && confirmPwd.length > 0){
        if(pwd != confirmPwd){
          alert('輸入密碼與確認(rèn)密碼不一致');
          return false;
        }
      }
 
      /*判斷密碼中是否存在用戶名*/
      if (pwd.indexOf(userName) >= 0) {
        alert('密碼中不能出現(xiàn)用戶名為' + userName);
        return false;
      }
 
      if (!eval('/' + this.arrRegex[0] + '/').test(pwd)) {
        alert('密碼沒(méi)有包含數(shù)字');
        return false;
      }
 
      if (!eval('/' + this.arrRegex[1] + '/').test(pwd)) {
        alert('密碼沒(méi)有包含小寫(xiě)字母');
        return false;
      }
 
      if (!eval('/' + this.arrRegex[2] + '/').test(pwd)) {
        alert('密碼沒(méi)有包含大寫(xiě)字母');
        return false;
      }
 
      if (!eval('/' + this.arrRegex[3] + '/').test(pwd)) {
        alert('密碼沒(méi)有包含!@#$%&*_等至少一個(gè)特殊字符');
        return false;
      }
 
      /*判斷是否存在過(guò)濾性字符串*/
      if(this.filter.length > 0){
        for(var i = 0, length = this.filter.length; i < length; i++){
          var value = this.filter[i];
 
          if(pwd.indexOf(value) < 0){
            continue;
          }
 
          alert("密碼中不允許含有"+ value);
 
          return false;
        }
      }
 
      /*判斷是否存在重復(fù)字符串*/
      if(this.isRepeate(pwd)){
        alert('密碼中不能出現(xiàn)重復(fù)字符');
        return false;
      }
 
      /*判斷是否存在連續(xù)性字符串*/
      if(this.isSeries(pwd)){
        alert('密碼中不能存在'+ this.seriesCount +'個(gè)以上的連續(xù)字符');
        return false;
      }
 
      return true;
    },
 
    /**
     * 是否存在重復(fù)字符串
     * @param pwd    密碼
     * @returns {boolean}
     */
    isRepeate : function(pwd){
      if(pwd && pwd.length > 0){
        for(var i = 0, length = pwd.length; i < length; i++){
          var currentChar = pwd.charAt(i);
          var prevChar  = i == 0 ? "" : pwd.charAt(i - 1);
 
          if(currentChar == prevChar){
            return true;
          }
        }
      }
 
      return false;
    },
 
    /**
     * 是否存在連續(xù)性字符串
     * @param pwd    密碼
     * @returns {boolean}
     */
    isSeries : function(pwd){
      if(pwd && pwd.length > 0) {
        /*自身算起*/
        var ascSeriesCount = 1;
        var descSeriesCount= 1;
 
        /*存在順序型的連續(xù)性的字符串*/
        for (var i = 0, length = pwd.length; i < length; i++) {
          var currentCharCode = pwd.charCodeAt(i);
          var prevCharCode  = i == 0 ? "" : pwd.charCodeAt(i - 1);
 
          if(currentCharCode == prevCharCode + 1){
            ascSeriesCount++;
 
            if(ascSeriesCount == this.seriesCount){
              return true;
            }
          } else{
            ascSeriesCount = 1;
          }
        }
 
        /*存在逆序性的連續(xù)性的字符串*/
        for (var i = pwd.length - 1; i >= 0; i--) {
          var currentCharCode = pwd.charCodeAt(i);
          var prevCharCode  = (i - 1) >= 0 ? pwd.charCodeAt(i - 1) : "";
 
          if(currentCharCode + 1 == prevCharCode){
            descSeriesCount++;
 
            if(descSeriesCount == this.seriesCount){
              return true;
            }
          } else{
            descSeriesCount = 1;
          }
        }
      }
 
      return false;
    },
 
    /**
     * 初始化方法
     * @param userNameId  用戶id
     * @param pwdId
     */
    init : function(userNameId, pwdId){
      $("#"+ pwdId).on("blur", function(){
        var userName = $("#"+ userNameId).val();
        var pwd = this.value;
 
        if(userName.length == 0){
          $("#"+ userNameId).focus();
          alert("請(qǐng)輸入用戶名");
 
          return false;
        }
 
        /*若驗(yàn)證正確,進(jìn)行加密處理*/
        if(this.verify(userName, pwd)){
          pwd = md5(pwd);
          $("#"+ pwdId).val(pwd);
        }
      });
    }
  }
})(window, undefined);

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

相關(guān)文章

  • React Native登錄之指紋登錄篇的示例代碼

    React Native登錄之指紋登錄篇的示例代碼

    這篇文章主要介紹了React Native登錄之指紋登錄篇,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • 詳解微信小程序回到頂部的兩種方式

    詳解微信小程序回到頂部的兩種方式

    這篇文章主要介紹了詳解微信小程序回到頂部的兩種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • JavaScript實(shí)現(xiàn)將UPC轉(zhuǎn)換成ISBN的方法

    JavaScript實(shí)現(xiàn)將UPC轉(zhuǎn)換成ISBN的方法

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)將UPC轉(zhuǎn)換成ISBN的方法,涉及javascript字符串操作的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • Js類的靜態(tài)方法與實(shí)例方法區(qū)分及jQuery拓展的兩種方法

    Js類的靜態(tài)方法與實(shí)例方法區(qū)分及jQuery拓展的兩種方法

    這篇文章主要介紹了Js類的靜態(tài)方法與實(shí)例方法區(qū)分及jQuery拓展的兩種方法 的相關(guān)資料,對(duì)靜態(tài)方法(Static)和實(shí)例方法(非Static)不太理解的朋友可以一起學(xué)習(xí)下
    2016-06-06
  • C++中的string類的用法小結(jié)

    C++中的string類的用法小結(jié)

    通過(guò)在網(wǎng)站上的資料搜集,得到了很多關(guān)于string類用法的文檔,通過(guò)對(duì)這些資料的整理和加入一些自己的代碼,就得出了一份比較完整的關(guān)于string類函數(shù)有哪些和怎樣用的文檔了!
    2015-08-08
  • 提高團(tuán)隊(duì)代碼質(zhì)量利器ESLint及Prettier詳解

    提高團(tuán)隊(duì)代碼質(zhì)量利器ESLint及Prettier詳解

    這篇文章主要為大家介紹了提高團(tuán)隊(duì)代碼質(zhì)量利器ESLint及Prettier使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • js 多種變量定義(對(duì)象直接量,數(shù)組直接量和函數(shù)直接量)

    js 多種變量定義(對(duì)象直接量,數(shù)組直接量和函數(shù)直接量)

    js 多種變量定義(對(duì)象直接量,數(shù)組直接量和函數(shù)直接量),大家可以參考下,對(duì)于以后學(xué)習(xí)js 面向?qū)τ谂cjson操作會(huì)有幫助。
    2010-05-05
  • JavaScript中三種引入方式的使用詳解

    JavaScript中三種引入方式的使用詳解

    JavaScript(簡(jiǎn)稱“JS”)是一種具有函數(shù)優(yōu)先的輕量級(jí),解釋型或即時(shí)編譯型的編程語(yǔ)言,本文主要為大家介紹了JavaScript中三種常見(jiàn)引入方式,希望對(duì)大家有所幫助
    2024-01-01
  • js實(shí)現(xiàn)樓層導(dǎo)航功能

    js實(shí)現(xiàn)樓層導(dǎo)航功能

    本文主要介紹了js實(shí)現(xiàn)樓層導(dǎo)航功能的示例,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-02-02
  • 微信小程序中實(shí)現(xiàn)自定義Navbar方法詳解

    微信小程序中實(shí)現(xiàn)自定義Navbar方法詳解

    這篇文章主要介紹了微信小程序中實(shí)現(xiàn)自定義Navbar方法,Navbar由 StatusBar和TitleBar組成,只需要知道它們各自的高度,就可以很好地完成自定義,需要的朋友可以參考下
    2024-05-05

最新評(píng)論