- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
NET Atlas开发检测密码强度的自定义Behavior
本文源于维生素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 欢迎光临学网,收藏本篇文章 [1] [2] [3] $False$ $(_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); } } 您也可以很方便的添加一些更花哨的功能,例如对于不同强度的输入,提示文字的背景颜色有所改变等。完整
有哪些信誉好的足球投注网站
文档评论(0)