电子邮件地址属性验证规则

5

我一直在我的代码中使用System.ComponentModel.DataAnnotations中的EmailAddressAttribute,并且一直运行良好。 BA和测试人员需要知道它如何验证电子邮件地址的规则。 由于我的正则表达式技能有限,因此我无法理解900个字符长的正则表达式。

有人可以用简单的语言解释规则吗?


6
您的测试人员应自行创建针对认为应该通过和失败的电子邮件的测试用例。仅告诉测试人员什么会起作用有什么意义呢?他们只需要关注它是否能够按照广告所述的功能执行,而不必关心它是如何实现的。 - Matthew
1个回答

5

基本上,在电子邮件地址字符串中,您有“@”符号之前和之后的文本。

文本中的每个字符应符合2个规则:

  1. [a-z]|\d|[!#\$%&'*+-/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]
  2. 如下所列的一些Unicode代码规则。

第一个规则意味着文本中的字符可以是以下之一:

  • a-z
  • 任何数字
  • 以下之一:!#\$%&'*+-/=\?\^_`{\|}~
  • 在Unicode范围内\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF

然后将文本用.分隔。


应该像这样:

private static Regex _regex = new Regex(@"^
(
    (
        ([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+
        (\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*
    )
    |
    (
        (\x22)
        (
        (((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?
        (
            ([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|
            (\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))
        )
        )*
        (((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)
    )
)

@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$", RegexOptions.Compiled | RegexOptions.IgnoreCase | RegexOptions.ExplicitCapture);

4
我认为他想要一个更简洁的解释这个特定表达方式。 - nixon

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接