我一直在我的代码中使用 EmailAddressAttribute(来自 System.ComponentModel.DataAnnotations),它运行良好。BA 和测试人员需要了解有关如何验证电子邮件地址的规则。我可以制作正则表达式的首尾,因为它有 900 个字符长,而且我的正则表达式技能有限。
谁能用简单的语言向我解释规则?
我一直在我的代码中使用 EmailAddressAttribute(来自 System.ComponentModel.DataAnnotations),它运行良好。BA 和测试人员需要了解有关如何验证电子邮件地址的规则。我可以制作正则表达式的首尾,因为它有 900 个字符长,而且我的正则表达式技能有限。
谁能用简单的语言向我解释规则?
基本上,在电子邮件地址字符串中,“@”符号前后都有文本。
文本中的每个字符都应符合 2 条规则:
[a-z]|\d|[!#\$%&'*+-/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]
第一条规则意味着文本中的字符可以是以下之一:
!#\$%&'*+-/=\?\^_`{\|}~
\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);