JavaScript用户密码安全强度判定

判断用户输入的字符组合
服务器君一共花费了152.186 ms进行了4次数据库查询,努力地为您提供了这个页面。
试试阅读模式?希望听取您的建议

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

本文地址:http://www.nowamagic.net/librarys/veda/detail/401,欢迎访问原出处。

不打个分吗?

转载随意,但请带上本文地址:

http://www.nowamagic.net/librarys/veda/detail/401

如果你认为这篇文章值得更多人阅读,欢迎使用下面的分享功能。
小提示:您可以按快捷键 Ctrl + D,或点此 加入收藏

阅读一百本计算机著作吧,少年

很多人觉得自己技术进步很慢,学习效率低,我觉得一个重要原因是看的书少了。多少是多呢?起码得看3、4、5、6米吧。给个具体的数量,那就100本书吧。很多人知识结构不好而且不系统,因为在特定领域有一个足够量的知识量+足够良好的知识结构,系统化以后就足以应对大量未曾遇到过的问题。

奉劝自学者:构建特定领域的知识结构体系的路径中再也没有比学习该专业的专业课程更好的了。如果我的知识结构体系足以囊括面试官的大部分甚至吞并他的知识结构体系的话,读到他言语中的一个词我们就已经知道他要表达什么,我们可以让他坐“上位”毕竟他是面试官,但是在知识结构体系以及心理上我们就居高临下。

所以,阅读一百本计算机著作吧,少年!

《深入理解MySQL核心技术》 Sasba Pacbev (作者), 李芳 (译者), 于红芸 (译者), 邵健 (译者)

《深入理解MySQL核心技术》:从公共可用性的意义上讲,MySQL源代码是开放源代码,但如果对其不了解,则实质上,它对于您来说是封闭的。MysQL开发团队的前成员Sasha Pachev通过《深入理解MySQL核心技术》给出了MySQL 5的全面指南,揭示了这一强大数据库的内部运作。您将直奔MySQL核心技术,了解各种数据结构和各种方便的功能的运作情况,了解如何添加新的存储引擎和配置选项等。 《深入理解MySQL核心技术》从结构概况讲起,在这一部分解释了MysQL的不同组件是如何协同工作的。接着将学习设置有效的可编译代码副本的步骤,然后使用基本架构添加自己的配置变量和存储引擎。

更多计算机宝库...