JS密码生成与强度检测完整实例(附demo源码下载)
作者:bea
本文实例讲述了JS密码生成与强度检测的方法。分享给大家供大家参考,具体如下: 1. 生成强密码 截图如下: 相关代码如下: function getPwd(n){ var s = ''; while(n--) s += String.fromCharCode(33 + Math.floor(Math.random()*(126-33))) document.getElementById('txt1').value = s;} 2. 计算密码破解时间 截图如下: 相关
本文实例讲述了JS密码生成与强度检测的方法。分享给大家供大家参考,具体如下:
1. 生成强密码
截图如下:
相关代码如下:
function getPwd(n)
{
var s = '';
while(n--)
s += String.fromCharCode(33 + Math.floor(Math.random()*(126-33)))
document.getElementById('txt1').value = s;
}
2. 计算密码破解时间
截图如下:
相关代码如下:
function getTime()
{
var str = '预计破解用时:';
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 + '时' + str;
s = Math.floor(s / 24);
if(s >= 1) str = s + '天' + str;
return str;
}
3. 密码安全检测
截图如下:
相关代码如下:
function showPwd()
{
var p = document.getElementById('txt2').value;
if(p.length < 4)
{
showError('密码至少4位!');
return;
}
var o = checkPwd(p);
if(o.isSame)
{
showError('密码为重复字符!');
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 = '密码长度:' + p.length + ' 强度:' + pwdNum + ' 预计破解用时:' + formatTime(num / (1024*1024*1024*2.4*2));
var span1 = document.getElementById('span1');
span1.style.color = 'blue';
span1.innerHTML = str;
}
4. 检测键盘是否大写锁定(Caps Lock键状态)
截图如下:
相关代码如下:
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);
}
}
完整实例代码点击此处本站下载。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
PS:对密码感兴趣的读者还可以参考一下本站密码相关工具:
密码安全性在线检测
高强度密码生成器
MD5在线加密工具
在线生成htpasswd工具
URL网址16进制加密工具
Escape加密/解密工具
迅雷、快车、旋风URL加密/解密工具
希望本文所述对大家JavaScript程序设计有所帮助。
有用 | 无用
1. 生成强密码
截图如下:
相关代码如下:
function getPwd(n)
{
var s = '';
while(n--)
s += String.fromCharCode(33 + Math.floor(Math.random()*(126-33)))
document.getElementById('txt1').value = s;
}
2. 计算密码破解时间
截图如下:
相关代码如下:
function getTime()
{
var str = '预计破解用时:';
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 + '时' + str;
s = Math.floor(s / 24);
if(s >= 1) str = s + '天' + str;
return str;
}
3. 密码安全检测
截图如下:
相关代码如下:
function showPwd()
{
var p = document.getElementById('txt2').value;
if(p.length < 4)
{
showError('密码至少4位!');
return;
}
var o = checkPwd(p);
if(o.isSame)
{
showError('密码为重复字符!');
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 = '密码长度:' + p.length + ' 强度:' + pwdNum + ' 预计破解用时:' + formatTime(num / (1024*1024*1024*2.4*2));
var span1 = document.getElementById('span1');
span1.style.color = 'blue';
span1.innerHTML = str;
}
4. 检测键盘是否大写锁定(Caps Lock键状态)
截图如下:
相关代码如下:
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);
}
}
完整实例代码点击此处本站下载。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
PS:对密码感兴趣的读者还可以参考一下本站密码相关工具:
密码安全性在线检测
高强度密码生成器
MD5在线加密工具
在线生成htpasswd工具
URL网址16进制加密工具
Escape加密/解密工具
迅雷、快车、旋风URL加密/解密工具
希望本文所述对大家JavaScript程序设计有所帮助。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- js类式继承与原型式继承详解
- javascript原型继承工作原理和实例详解
- 浅析JS原型继承与类的继承
- AngularJs 弹出模态框(model)
- 详解AngularJS 模态对话框
- 分离与继承的思想实现图片上传后的预览功能:ImageUploadView
- jQuery动态添加<input type="file">
- javascript模块化简单解析
- jquery编写Tab选项卡滚动导航切换特效
- js仿QQ中对联系人向左滑动、滑出删除按钮的操作
- jQuery实现简单滚动动画效果
- 基于javascript bootstrap实现生日日期联动选择
- 原生js制作日历控件实例分享
- 基于HTML模板和JSON数据的JavaScript交互(移动端)
- JavaScript中实现无缝滚动、分享到侧边栏实例代码
- jQuery实现内容定时切换效果完整实例
- jQuery隐藏和显示效果实现
- JS动态改变浏览器标题的方法
- jQuery ajax提交Form表单实例(附demo源码)