首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Coldfusion RegEx检查密码的强度

Coldfusion RegEx检查密码的强度
EN

Stack Overflow用户
提问于 2012-06-13 04:38:59
回答 4查看 3.5K关注 0票数 2

我正在使用这个来验证ColdFusion 7中的“强”密码。

代码语言:javascript
运行
复制
if ( REFind("^(?=.*[A-Z])(?=.*[!@##$&*])(?=.*[0-9])(?=.*[a-z]).{6}$", myPassword, 1) EQ 0 )

然而,它正在失败。有人能指出我的错误吗?

我认为我测试的标准是:

  • 1上
  • 1下
  • 1数字
  • 1特殊字符

H 1106位数minH 211F 212

非CF人员的脚注:

hash;

  • ColdFusion使用Oro2.0.6作为regex引擎
EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2012-06-13 14:14:26

好吧,你试着测试的标准是很糟糕的。

例如,Pa$5word符合标准,但是一个糟糕的选择,而my name |z NOT Fr£d强得多,但失败了(没有数字,不同的符号)。

理想情况下,您应该寻找和现有的密码强度检查(虽然我不知道是否有任何现有的/好的)。

无论如何,对于您所要求的内容的简单解决方案,详细说明正在检查的内容,只需这样做:

代码语言:javascript
运行
复制
<cfif NOT 
    ( len(myPassword) GTE 6
    AND refind('[A-Z]',myPassword)
    AND refind('[a-z]',myPassword)
    AND refind('[0-9]',myPassword)
    AND refind('[!@##$&*]',myPassword)
     )>

把所有的东西都弄成一个正则表达式是没有必要的/好处的。

票数 6
EN

Stack Overflow用户

发布于 2012-06-13 07:19:25

它可能失败的原因之一是您的业务规则是“至少6个字符”,但是regex强制执行的正是6个字符。

另外:这会很有帮助的,你说了哪些条件失败了。我表面上的测试表明你很好,除了我上面提到的警告。如果你能把你的问题弄清楚,指出我没有想到的非表面测试失败了,那将是有帮助的。

在现实世界中,我也希望你认为哪些标点符号是有效的。你的名单有点短。但这与你目前的问题无关。

票数 0
EN

Stack Overflow用户

发布于 2012-06-13 10:54:57

尝尝这个。

^(?=.A-Z)(?=.!@##\$&_)(?=.0-9)(?=.*a-z).{6,}$

在6后面添加逗号,因为您希望允许超过6个字符,$必须用\$转义

更新

在下面尝试,^和$从上面移除

(?=.A-Z)(?=.!@##$&_)(?=.0-9)(?=.*a-z).{6,}

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11008278

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档