JS用户密码安全强度判定

判断用户输入的密码,然后告诉用户其密码的强度是一个很好的用户体验设计,一来可以提高用户密码的安全度,也可以让用户对网站产生信任感。下面是一个简单的判断用户密码强度的JavaScript程序。

效果演示
输入密码:
密码强度:
温馨提示:密码至少需要4个字符,并且最好包含数字,字母(大小写都有)与特殊符号。

分析

密码已经是我们生活工作中必不可少的工具,但一个不安全的密码有又有可能会给我们造成不必要的损失。作为网站设计者,如果我们在网页中能对用户输入的密码进行安全评估,并显示出相应的提示信息,那么对用户设置一个安全的密码将有很大帮助。同时也使得网站更具人性化,更有吸引力。

什么是一个安全的密码呢?本程序按以下的方式进行评估。

  • 如果密码少于5位,那么就认为这是一个弱密码。
  • 如果密码只由数字、小写字母、大写字母或其它特殊符号当中的一种组成,则认为这是一个弱密码。
  • 如果密码由数字、小写字母、大写字母或其它特殊符号当中的两种组成,则认为这是一个中度安全的密码。
  • 如果密码由数字、小写字母、大写字母或其它特殊符号当中的三种以上组成,则认为这是一个比较安全的密码。
程序代码
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
<script language=javascript> 
//CharMode函数 
//测试某个字符是属于哪一类. 
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; 
} 
//checkStrong函数 
//返回密码的强度级别 
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); 
} 
//pwStrength函数.www.qichepeijian.com 
//当用户放开键盘或密码输入框失去焦点时,根据不同的级别显示不同的颜色 
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> 
<form name="form1" action="" > 
<table width="400" border="0">
  <tr>
    <td width="25%">输入密码:</td>
    <td width="75%"><input type="password" size="40" onKeyUp="pwStrength(this.value)" onBlur="pwStrength(this.value)"> </td>
  </tr>
  <tr>
    <td>密码强度:</td>
    <td>
<table width="300" border="1" bordercolor="#cccccc" height="23"> 
	<tr bgcolor="#eeeeee"> 
		<td width="100" id="strength_L">弱</td> 
		<td width="100" id="strength_M">中</td> 
		<td width="100" id="strength_H">强</td> 
	</tr> 
</table> 
    </td>
  </tr>
  <tr>
    <td>温馨提示:</td>
    <td>密码至少需要4个字符,并且最好包含数字,字母(大小写都有)与特殊符号。</td>
  </tr>
</table>
</form>

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值