js密码强度检测


Posted in Javascript onJanuary 07, 2016

本文实例讲解了js密码强度检测的实现代码,分享给大家供大家参考,具体内容如下

运行效果图:

js密码强度检测

这段JavaScript代码比较实用,它完成用户注册时判断用户输入密码的强度,分强、弱、中三等级,它可以根据用户输入的密码显示对应的密码强弱等级,方便用户改进输入。

实现代码:

<html>
<head>
<title>JS判断密码强度</title>
<script language=javascript> 
//判断输入密码的类型 
function CharMode(iN){ 
if (iN>=48 && iN <=57) //数字 
return 1; 
if (iN>=65 && iN <=90) //大写 
return 2; 
if (iN>=97 && iN <=122) //小写 
return 4; 
else 
return 8;  
} 
//bitTotal函数 
//计算密码模式 
function bitTotal(num){ 
modes=0; 
for (i=0;i<4;i++){ 
if (num & 1) modes++; 
num>>>=1; 
} 
return modes; 
} 
//返回强度级别 
function checkStrong(sPW){ 
if (sPW.length<=4) 
return 0; //密码太短 
Modes=0; 
for (i=0;i<sPW.length;i++){ 
//密码模式 
Modes|=CharMode(sPW.charCodeAt(i)); 
} 
return bitTotal(Modes); 
} 
 
//显示颜色 
function pwStrength(pwd){ 
O_color="#eeeeee"; 
L_color="#FF0000"; 
M_color="#FF9900"; 
H_color="#33CC00"; 
if (pwd==null||pwd==''){ 
Lcolor=Mcolor=Hcolor=O_color; 
} 
else{ 
S_level=checkStrong(pwd); 
switch(S_level) { 
case 0: 
Lcolor=Mcolor=Hcolor=O_color; 
case 1: 
Lcolor=L_color; 
Mcolor=Hcolor=O_color; 
break; 
case 2: 
Lcolor=Mcolor=M_color; 
Hcolor=O_color; 
break; 
default: 
Lcolor=Mcolor=Hcolor=H_color; 
} 
} 
document.getElementById("strength_L").style.background=Lcolor; 
document.getElementById("strength_M").style.background=Mcolor; 
document.getElementById("strength_H").style.background=Hcolor; 
return; 
} 
</script>
</head>
<body> 
<form name=form1 action="" > 
密码:<input type=password size=8 onKeyUp=pwStrength(this.value) onBlur=pwStrength(this.value)> 
<br>密码强度: 
<table width="210" border="1" cellspacing="0" cellpadding="1" bordercolor="#eeeeee" height="22" style='display:inline'> 
<tr align="center" bgcolor="#f5f5f5"> 
<td width="33%" id="strength_L">弱</td> 
<td width="33%" id="strength_M">中</td> 
<td width="33%" id="strength_H">强</td> 
</tr> 
</table> 
</form>
</body>
</html>

这一款先看一看效果图。

js密码强度检测

具体内容:

<script>
function AuthPasswd(string) {
 if(string.length >=6) {
  if(/[a-zA-Z]+/.test(string) && /[0-9]+/.test(string) && /\W+\D+/.test(string)) {
   noticeAssign(1);
  }else if(/[a-zA-Z]+/.test(string) || /[0-9]+/.test(string) || /\W+\D+/.test(string)) {
   if(/[a-zA-Z]+/.test(string) && /[0-9]+/.test(string)) {
    noticeAssign(-1);
   }else if(/\[a-zA-Z]+/.test(string) && /\W+\D+/.test(string)) {
    noticeAssign(-1);
   }else if(/[0-9]+/.test(string) && /\W+\D+/.test(string)) {
    noticeAssign(-1);
   }else{
    noticeAssign(0);
   }
  }
 }else{
  noticeAssign(null); 
 }
}
 
function noticeAssign(num) {
 if(num == 1) {
  $('#weak').css({backgroundColor:'#009900'});
  $('#middle').css({backgroundColor:'#009900'});
  $('#strength').css({backgroundColor:'#009900'});
  $('#strength').html('很强');
  $('#middle').html('');
  $('#weak').html('');
 }else if(num == -1){
  $('#weak').css({backgroundColor:'#ffcc33'});
  $('#middle').css({backgroundColor:'#ffcc33'});
  $('#strength').css({backgroundColor:''});
  $('#weak').html('');
  $('#middle').html('中');
  $('#strength').html('');
 }else if(num ==0) {
  $('#weak').css({backgroundColor:'#dd0000'});
  $('#middle').css({backgroundColor:''});
  $('#strength').css({backgroundColor:''});
  $('#weak').html('弱');
  $('#middle').html('');
  $('#strength').html('');
 }else{
  $('#weak').html(' ');
  $('#middle').html(' ');
  $('#strength').html(' ');
  $('#weak').css({backgroundColor:''});
  $('#middle').css({backgroundColor:''});
  $('#strength').css({backgroundColor:''});
 }
}
</script>

以上就是本文的全部内容,希望对大家学习javascript程序设计有所帮助。

Javascript 相关文章推荐
将HTML自动转为JS代码
Jun 26 Javascript
jquery如何判断某元素是否具备指定的样式
Nov 05 Javascript
javasciprt下jquery函数$.post执行无响应的解决方法
Mar 13 Javascript
深入理解JavaScript系列(42):设计模式之原型模式详解
Mar 04 Javascript
js模仿php中strtotime()与date()函数实现方法
Aug 11 Javascript
跟我学习javascript的Date对象
Nov 19 Javascript
BootStrap 弹出层代码
Feb 09 Javascript
Babel 入门教程学习笔记
Jun 13 Javascript
vue devtools的安装与使用教程
Aug 08 Javascript
angular4中*ngFor不能对返回来的对象进行循环的解决方法
Sep 12 Javascript
js中的this的指向问题详解
Aug 29 Javascript
用vue写一个日历
Nov 02 Javascript
实例详解JSON数据格式及json格式数据域字符串相互转换
Jan 07 #Javascript
基于JavaScript实现通用tab选项卡(通用性强)
Jan 07 #Javascript
基于JavaScript代码实现兼容各浏览器的设为首页和加入收藏
Jan 07 #Javascript
JavaScript设计模式初探
Jan 07 #Javascript
JavaScript类型系统之Object详解
Jan 07 #Javascript
7个去伪存真的JavaScript面试题
Jan 07 #Javascript
jQuery表格插件datatables用法详解
Nov 23 #Javascript
You might like
PHP中Date获取时间不正确怎么办
2008/06/05 PHP
php判断字符串在另一个字符串位置的方法
2014/02/27 PHP
Zend Framework动作助手FlashMessenger用法详解
2016/03/05 PHP
CodeIgniter连贯操作的底层原理分析
2016/05/17 PHP
js宝典学习笔记(上)
2007/01/10 Javascript
this和执行上下文实现代码
2010/07/01 Javascript
$.format,jquery.format 使用说明
2011/07/13 Javascript
基于jQuery实现文本框只能输入数字(小数、整数)
2016/01/14 Javascript
Bootstrap carousel轮转图的使用实例详解
2016/05/17 Javascript
全面解析Bootstrap中transition、affix的使用方法
2016/05/30 Javascript
js中的关联数组与普通数组详解
2016/07/27 Javascript
js实现带缓动动画的导航栏效果
2017/01/16 Javascript
js中的触发事件对象event.srcElement与event.target详解
2017/03/15 Javascript
详解如何在React组件“外”使用父组件的Props
2018/01/12 Javascript
react-native-video实现视频全屏播放的方法
2018/03/19 Javascript
vue如何在自定义组件中使用v-model
2018/05/14 Javascript
详解使用create-react-app添加css modules、sasss和antd
2018/07/31 Javascript
js canvas实现星空连线背景特效
2019/11/01 Javascript
小程序新版订阅消息模板消息
2019/12/31 Javascript
[41:37]DOTA2北京网鱼队选拔赛——冲击职业之路
2015/04/13 DOTA
[01:38]【DOTA2亚洲邀请赛】Sumail——梦开始的地方
2017/03/03 DOTA
python中enumerate函数遍历元素用法分析
2016/03/11 Python
python numpy函数中的linspace创建等差数列详解
2017/10/13 Python
python中多层嵌套列表的拆分方法
2018/07/02 Python
Python玩转PDF的各种骚操作
2019/05/06 Python
python或C++读取指定文件夹下的所有图片
2019/08/31 Python
python中的socket实现ftp客户端和服务器收发文件及md5加密文件
2020/04/01 Python
详解tensorflow2.x版本无法调用gpu的一种解决方法
2020/05/25 Python
详解Canvas事件绑定
2018/06/27 HTML / CSS
Elizabeth Gage官网:英国最好的珠宝设计之一
2020/09/26 全球购物
服装设计师职业生涯规划范文
2014/02/28 职场文书
西游记读书笔记
2015/06/25 职场文书
css3带你实现3D转换效果
2022/02/24 HTML / CSS
JavaWeb Servlet开发注册页面实例
2022/04/11 Java/Android
python中pymysql包操作数据库方法
2022/04/19 Python
Pandas 数据编码的十种方法
2022/04/20 Python