利用javascript如何隨機生成一定位數(shù)的密碼
前言
本文主要給大家介紹了關(guān)于利用javascript隨機生成一定位數(shù)密碼的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多少,來一起看看詳細(xì)的介紹吧。
需求
隨機生成一定位數(shù)的密碼,有最小個數(shù)和最大個數(shù),必須包含數(shù)字、大小寫字母,和特殊字符比如(- _ #);
代碼
function createPassword(min,max) { //可以生成隨機密碼的相關(guān)數(shù)組 var num = ["0","1","2","3","4","5","6","7","8","9"]; var english = ["a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z"]; var ENGLISH = ["A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"]; var special = ["-","_","#"]; var config = num.concat(english).concat(ENGLISH).concat(special); //先放入一個必須存在的 var arr = []; arr.push(getOne(num)); arr.push(getOne(english)); arr.push(getOne(ENGLISH)); arr.push(getOne(special)); //獲取需要生成的長度 var len = min + Math.floor(Math.random()*(max-min+1)); for(var i=4; i<len; i++){ //從數(shù)組里面抽出一個 arr.push(config[Math.floor(Math.random()*config.length)]); } //亂序 var newArr = []; for(var j=0; j<len; j++){ newArr.push(arr.splice(Math.random()*arr.length,1)[0]); } //隨機從數(shù)組中抽出一個數(shù)值 function getOne(arr) { return arr[Math.floor(Math.random()*arr.length)]; } return newArr.join(""); }
使用
傳入一個生成的密碼的最小位數(shù),和最大位數(shù),即可返回一個隨機密碼
console.log(createPassword(8,15));
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
靈活應(yīng)用js調(diào)試技巧解決樣式問題的步驟分享
在很多時候,前端開發(fā)人員使用JS腳本,對頁面Dom結(jié)構(gòu)或者是樣式做出了修改,會造成一些意想不到的bug2012-03-03如何在?xHTML?中驗證?noscript+meta?refresh?標(biāo)簽
這篇文章主要介紹了如何在?xHTML?中驗證?noscript+meta?refresh?標(biāo)簽,需要的朋友可以參考下2023-03-03如何用JS實現(xiàn)簡單的數(shù)據(jù)監(jiān)聽
這篇文章主要介紹了如何用JS實現(xiàn)簡單的數(shù)據(jù)監(jiān)聽,對數(shù)據(jù)監(jiān)聽感興趣的同學(xué),可以參考一下2021-05-05javascript 控制input只允許輸入的各種指定內(nèi)容
這篇文章主要介紹了通過javascript控制input只允許輸入的各種指定內(nèi)容,需要的朋友可以參考下2014-06-06JS數(shù)組索引檢測中的數(shù)據(jù)類型問題詳解
這篇文章主要給大家介紹了關(guān)于JS數(shù)組索引檢測中的數(shù)據(jù)類型問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01