JS密碼生成與強(qiáng)度檢測(cè)完整實(shí)例(附demo源碼下載)
本文實(shí)例講述了JS密碼生成與強(qiáng)度檢測(cè)的方法。分享給大家供大家參考,具體如下:
1. 生成強(qiáng)密碼
截圖如下:
相關(guān)代碼如下:
function getPwd(n) { var s = ''; while(n--) s += String.fromCharCode(33 + Math.floor(Math.random()*(126-33))) document.getElementById('txt1').value = s; }
2. 計(jì)算密碼破解時(shí)間
截圖如下:
相關(guān)代碼如下:
function getTime() { var str = '預(yù)計(jì)破解用時(shí):'; var selChar = document.getElementById('selChar'); var txtPwdLen = document.getElementById('txtPwdLen'); var num = Math.pow(parseInt(selChar.value), parseInt(txtPwdLen.value)); str += formatTime(num / (1024*1024*1024*2.4*2)); document.getElementById('span2').innerHTML = str; } function formatTime(s) { var str = ''; if(s<1)return '小于1秒!'; s = Math.floor(s); if(s >= 1) str = s % 60 + '秒' + str; s = Math.floor(s / 60); if(s >= 1) str = s % 60 + '分' + str; s = Math.floor(s / 60); if(s >= 1) str = s % 24 + '時(shí)' + str; s = Math.floor(s / 24); if(s >= 1) str = s + '天' + str; return str; }
3. 密碼安全檢測(cè)
截圖如下:
相關(guān)代碼如下:
function showPwd() { var p = document.getElementById('txt2').value; if(p.length < 4) { showError('密碼至少4位!'); return; } var o = checkPwd(p); if(o.isSame) { showError('密碼為重復(fù)字符!'); return; } for(var i=0; i<arrPwd.length; i++) { if(arrPwd[i] == p || arrPwd[i].indexOf(p) == 0) { showError('密碼為100大常用密碼!'); return; } } var year = parseInt(p.substr(0,4)); if(!isNaN(year) && year>1900 && year<2100) { var month = parseInt(p.substr(4,2)); if(!isNaN(month) && month>0 && month<13) { var day = parseInt(p.substr(6,2)); if(!isNaN(day) && day>0 && day<32) { showError('不要使用日期作為密碼!'); return; } } } var hasUpper = false; var hasLow = false; var hasNum = false; var hasOther = false; for(var i=0; i<p.length; i++) { var c = p.charCodeAt(i); if(c>=65&&c<=90)hasUpper=true; else if(c>=97&&c<=122)hasLow=true; else if(c>=48&&c<=57)hasNum=true; else hasOther=true; } var pwdNum = 0; if(hasUpper)pwdNum+=26; if(hasLow)pwdNum+=26; if(hasNum)pwdNum+=10; if(hasOther)pwdNum+=32; var num = Math.pow(pwdNum, p.length); var str = '密碼長(zhǎng)度:' + p.length + ' 強(qiáng)度:' + pwdNum + ' 預(yù)計(jì)破解用時(shí):' + formatTime(num / (1024*1024*1024*2.4*2)); var span1 = document.getElementById('span1'); span1.style.color = 'blue'; span1.innerHTML = str; }
4. 檢測(cè)鍵盤(pán)是否大寫(xiě)鎖定(Caps Lock鍵狀態(tài))
截圖如下:
相關(guān)代碼如下:
var $lock = false; function checkCapsLock(fn) { document.documentElement.onkeypress = function(e) { var e = e || event; var k = e.keyCode || e.which; var s = e.shiftKey || (k == 16) || false; if(k>=65&&k<=90)$lock=!s; if(k>=97&&k<=122)$lock=s; fn($lock); } document.documentElement.onkeyup = function(e) { var e = e || event; var k = e.keyCode || e.which; if(k==20)$lock = !$lock; fn($lock); } }
完整實(shí)例代碼點(diǎn)擊此處本站下載。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動(dòng)畫(huà)特效與技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
PS:對(duì)密碼感興趣的讀者還可以參考一下本站密碼相關(guān)工具:
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
js阻止默認(rèn)瀏覽器行為與冒泡行為的實(shí)現(xiàn)代碼
下面小編就為大家?guī)?lái)一篇js阻止默認(rèn)瀏覽器行為與冒泡行為的實(shí)現(xiàn)代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-05-05JavaScript中16進(jìn)制顏色與rgb顏色互相轉(zhuǎn)換的示例代碼
這篇文章主要介紹了JavaScript中16進(jìn)制顏色與rgb顏色互相轉(zhuǎn)換的示例代碼,通過(guò)示例代碼介紹了JS 顏色16進(jìn)制、rgba相互轉(zhuǎn)換問(wèn)題,感興趣的朋友一起看看吧2024-01-01js遍歷獲取表格內(nèi)數(shù)據(jù)的方法(必看)
下面小編就為大家?guī)?lái)一篇js遍歷獲取表格內(nèi)數(shù)據(jù)的方法(必看)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-04-04按下Enter焦點(diǎn)移至下一個(gè)控件的實(shí)現(xiàn)js代碼
正如標(biāo)題所言使用js操作按下Enter焦點(diǎn)移至下一個(gè)控件,具體的實(shí)現(xiàn)示例如下,需要的朋友可以參考下2013-12-12基于JS組件實(shí)現(xiàn)拖動(dòng)滑塊驗(yàn)證功能(代碼分享)
拖動(dòng)滑塊驗(yàn)證功能在支付寶,微信各大平臺(tái)都能見(jiàn)到這樣的功能,那么基于js組件是如何實(shí)現(xiàn)此功能的呢?今天小編就給大家分享下js 拖動(dòng)滑塊 驗(yàn)證功能的實(shí)現(xiàn)代碼,需要的朋友參考下吧2016-11-11JavaScript+html實(shí)現(xiàn)前端頁(yè)面滑動(dòng)驗(yàn)證(2)
這篇文章主要為大家詳細(xì)介紹了JavaScript+html實(shí)現(xiàn)前端頁(yè)面滑動(dòng)驗(yàn)證的第二種方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06uniapp介紹與使用以及小程序?qū)崟r(shí)獲取視頻播放時(shí)間
這篇文章主要給大家介紹了關(guān)于uniapp介紹與使用以及小程序?qū)崟r(shí)獲取視頻播放時(shí)間的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用uniapp具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-02-02