-1

想与社区确认并分享我的想法..

Active Directory 密码的正则表达式应验证密码

  1. 长度至少为六个字符
  2. 包含英文大写字符(A 到 Z)
  3. 包含英文小写字符(a 到 z)
  4. 包含 Base 10 位数字(0 到 9)
  5. 包含非字母字符(!、$、#、% ...)
  6. 不包含用户的帐户名或用户全名超过两个连续字符的部分

前 5 个条件很简单。

我发现这应该适用于 1-5 个条件:

(?=^.{8,255}$)((?=.*\d)(?=.*[A-Z])(?=.*[a-z])|(?=.*\d)(?=.*[^A-Za-z0-9])(?=.*[a-z])|(?=.*[^A-Za-z0-9])(?=.*[A-Z])(?=.*[a-z])|(?=.*\d)(?=.*[A-Z])(?=.*[^A-Za-z0-9]))^.*

但是如何添加条件 6 - 否定名称和登录?

我是这样看的:

首先得到禁止的东西:

String enter = fullname + login;

List<string> Negative = new List<string>();

for (int i = 0; i < enter.Length; i += 3)
{
    if (i + 3 > enter.Length)
    {
        enter.Substring(i, 3);
        Negative.Add(enter.Substring(i, 3));
    }

}

然后构建正则表达式:

StringBuilder pattern = new StringBuilder("(?=^.{8,255}$)((?=.*\d)(?=.*[A-Z])(?=.*[a-z])|(?=.*\d)(?=.*[^A-Za-z0-9])(?=.*[a-z])|(?=.*[^A-Za-z0-9])(?=.*[A-Z])(?=.*[a-z])|(?=.*\d)(?=.*[A-Z])(?=.*[^A-Za-z0-9]))");

foreach(string word in Negative)
{
    pattern.Append("(/^((?!" + word + @")[\s\S])*$/)");
}

pattern.Append("^.*");

该模式现在应该是所需的正则表达式。

我主要关心的是这行代码:

pattern.Append("(/^((?!" + word + @")[\s\S])*$/)");

它会添加否定条件word吗?

4

2 回答 2

2

正则表达式是一个很好的工具,但不能解决所有问题。例如,正则表达式在您需要的意义上算不上。是的,正则表达式可以计算例如连续的字母,但它不能检查您是否有其中两个和其他三个,分布在完整的输入字符串中。这也适用于您的具体问题。具体来说,在同一个正则表达式中检查这两个不同的条件可能会变得非常困难。

在这种情况下,我建议不要使用正则表达式,而只需编写一个小算法来执行所有检查。使用这种方法获得的另一个好处是,当他们稍后重新访问它时,普通人将能够理解你的算法。总是一个额外的好处。

于 2013-06-26T04:51:42.023 回答
0

您的第 5 个和第 1 个要求将导致此正则表达式

^.{6,}$

对于您的第 6 个要求,

考虑到您的帐户名称为accountName

input是你的目标输入密码

bool isNotValid= Regex.Matches(accountName,"(?=(..))")//capturing two consecutive characters of account name
                      .Cast<Match>()
                      .Select(m=>m.Groups[1].Value)//two consecutive character's list
                      .Any(y=>input.IndexOf(y)!=-1);

捕获两个连续字符与捕获两个以上连续字符一样好

我曾经(?=(..))捕获两个连续的字符。这将捕获he, el, ll, lofrom hello。

于 2013-06-26T04:59:45.453 回答