All articles| All Pictures| All Softwares| All Video| Go home page| Write articles| Upload pictures

Reading number is top 10 articles
动态网页PHP程序员的优化调试技术和技巧_php资料_编程技术
PHP正则表达式使用的方法_[PHP教程]
保护SQL,Server的十个步骤_[SQL,Server教程]
在asp.net2.0页面部分缓存中使用PartialCachingAttribu
实例详解网页表单格式的应用技巧_[Html教程]
自定义阿ASP.NET,CheckBox的设计思路_.net资料_编程技术
在PHP中全面阻止SQL注入式攻击之二_php资料_编程技术
PHP,PEAR简介_php资料_编程技术
让我们一起认识YAML:YAML简介_php资料_编程技术
SQL,Server开发的二十一条军规_[SQL,Server教程]
Reading number is top 10 pictures
网络游戏与脑残
The money of more than 100 countries and regions14
Beauty Sun Feifei
到底是谁撞谁呀?
The money of more than 100 countries and regions1
青春清纯美女大集合3
影评-疯子,我爱你
A letter to parents choose world of warcraft seven big reason
某某人向找小三的人宣战了
传销的好处
Download software ranking
Proficient in JavaScript
Boxer's Top ten classic battle2
仙剑奇侠传98版歌曲
仙剑奇侠传98硬盘WINXP版
天龙八部十二宫服务端
The Bermuda triangle1
1400篇各类破解文章
Unix video tutorial15
The cock of the Grosvenor LTD handsome
Tram sex maniac 2 (H) rar bag4
delv published in(发表于) 2014/1/6 9:09:11 Edit(编辑)
使用ASP.NET,Atlas开发检测密码强度的自定义Behavior_[Asp.Net教程]

使用ASP.NET,Atlas开发检测密码强度的自定义Behavior_[Asp.Net教程]

使用ASP.NET Atlas开发检测密码强度的自定义Behavior_[Asp.Net教程]























本文源于维生素C.net的一篇文章利用数学方法来大大降低一个逻辑判断实现的难度的例子。检测代码来自THIN的检验密码强度的JS类。




Atlas中提供了客户端JavaScript强大的面向对象功能,这几天看到了上述二位的帖子,觉得这个功能需求在日常开发中还是很常见的。晚上闲来无事,将上述功能封装为Atlas中的Behavior,以方便重用。关于Atlas的Behavior,请参考:在ASP.NET Atlas中创建自定义的Behavior。




按照在ASP.NET Atlas中创建自定义的Behavior这篇文章的五个自定义步骤,很容易写出了这个Behavior。其中最重要的部分为检验密码强度的算法,这里我偷了个懒,只是简单的将THIN的代码完全Copy过来(兄弟不要骂我-_-b),有心的朋友可以将它重构成更“Atlas”的样子。这个检测函数将在每次用户在相应的input中按键时被触发:




function keyPressHandler() {




// you may refactor this part to make the code more 'Atlas like' :-)
var PasswordStrength ={
Level : ["高,实在是高","还行啦","靠,这样也行"],
LevelValue : [30,20,0],//强度值
Factor : [1,2,5],//字符加数,分别为字母,数字,其它
KindFactor : [0,0,10,20],//密码含几种组成的加数
Regex : [/[a-zA-Z]/g,/\d/g,/[^a-zA-Z0-9]/g] //字符正则数字正则其它正则
}
PasswordStrength.StrengthValue = function(pwd)
{
var strengthValue = 0;
var ComposedKind = 0;
for(var i = 0 ; i < this.Regex.length;i++)
{
var chars = pwd.match(this.Regex[i]);
if(chars != null)
{
strengthValue += chars.length * this.Factor[i];
ComposedKind ++;
}
}
strengthValue += this.KindFactor[ComposedKind];
return strengthValue;
}
PasswordStrength.StrengthLevel = function(pwd)
{
var value = this.StrengthValue(pwd);
for(var i = 0 ; i < this.LevelValue.length ; i ++)
{
if(value >= this.LevelValue[i] )
return this.Level[i];
}
}
// end of the refactoring section

(_checkResultLabelID).innerHTML = PasswordStrength.StrengthLevel(this.control.element.value);
}




同时在这个Behavior中添加了属性checkResultLabelID,用来指定显示检验结果的Label:




var _checkResultLabelID;
this.get_checkResultLabelID = function() {
return _checkResultLabelID;
}
this.set_checkResultLabelID = function(value) {
if (_checkResultLabelID != value) {
_checkResultLabelID = value;
this.raisePropertyChanged('checkResultLabelID');
}
}




您也可以很方便的添加一些更花哨的功能,例如对于不同强度的输入,提示文字的背景颜色有所改变等。完整的源代码请参考本文后面的下载。




测试的步骤也很简单,首先在ScriptManager中添加这个Behavior的引用:











然后在页面上添加一个input,用来输入密码(演示程序中没有设定type为password),和一个span,用来显示检验结果:







Input a password:







最后,Atlas Script中将上面的input提升为Atlas控件,并加入我们刚刚写好的Behavior:







就是这么简单,浏览器中如下:




简单密码:







中等密码:




复杂密码:






作者:Dflying Chen 来源:博客园












































添加到del.icio.us 添加到新浪ViVi 添加到百度搜藏 添加到POCO网摘 添加到天天网摘365Key 添加到和讯网摘 添加到天极网摘 添加到黑米书签 添加到QQ书签 添加到雅虎收藏 添加到奇客发现 diigo it 添加到饭否 添加到飞豆订阅 添加到抓虾收藏 添加到鲜果订阅 digg it 貼到funP 添加到有道阅读 Live Favorites 添加到Newsvine 打印本页 用Email发送本页 在Facebook上分享


Disclaimer Privacy Policy About us Site Map

If you have any requirements, please contact webmaster。(如果有什么要求,请联系站长)
Copyright ©2011-
uuhomepage.com, Inc. All rights reserved.