.NET Framework和 .Net Core实现不一致的API之 `EmailAddressAttribute`

.NET Framework和 .Net Core实现不一致的API之 EmailAddressAttribute

Intro

现在我们的类库项目大多是 NETStandard2.0 项目,但是 netstandard2.0 只是一个标准接口定义,具体的实现还是要看实际运行的框架,如 netfx47 或 netcoreapp2.1,可能在大部分情况下,对外表现是一致的,但是,某一些 API 可能会不一致,这里就开一篇文章收集我所遇到的表现不一致的API。

EmailAddressAttribute

这个 EmailAddressAttribute 是用来验证输入的邮箱地址是否合法,在 dotnetframework 下的实现是用一个很复杂正则表达式去验证的,而 dotnetcore 下的实现则比较简单,并没有使用正则表达式去验证,只是验证了输入是否包含而且仅包含一个“@”,并且“@”不是第一个字符也不是最后一个字符,具体可以参考下面的链接

dotnet fx 472

dotnet fx 472 使用的正则表达式如下(看到我就已经头晕了。。。):

const string pattern = @"^((([a-z]|d|[!#$%&'*+-/=?^_`{|}~]|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF])+(.([a-z]|d|[!#$%&'*+-/=?^_`{|}~]|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF])+)*)|((x22)((((x20|x09)*(x0dx0a))?(x20|x09)+)?(([x01-x08x0bx0cx0e-x1fx7f]|x21|[x23-x5b]|[x5d-x7e]|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF])|(\([x01-x09x0bx0cx0d-x7f]|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF]))))*(((x20|x09)*(x0dx0a))?(x20|x09)+)?(x22)))@((([a-z]|d|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF])|(([a-z]|d|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF])([a-z]|d|-|.|_|~|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF])*([a-z]|d|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF]))).)+(([a-z]|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF])|(([a-z]|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF])([a-z]|d|-|.|_|~|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF])*([a-z]|[u00A0-uD7FFuF900-uFDCFuFDF0-uFFEF]))).?$";

需要注意的还有一点,就是上图中的 AppSettings.DisableRegEx,来看实现:

AppSettings.DisableRegEx

可以看到默认是 false,然而从 net472 之后默认就会是 true,会表现出和 .netcore 一致的行为,然而我用的是 net471,于是就发现了不一致,,,从上面的截图可以看到我们也可以在 app.config/web.config 文件中设置 AppSettings 节点,设置 key 为 dataAnnotations:dataTypeAttribute:disableRegEx ,value 为 true 来禁用使用正则。

dotnet fx472 source

dotnet core

dotnet core source

dotnet core 实现源码

Memo

如果你希望 EmailAddressAttribute 不修改配置就实现完全一致的行为,那么你可以升级 framework 到 net472 或者放弃使用这个,自己定义一个正则,使用 RegularExpressionAttribute,你可以用 [RegularExpression(@"^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$")] 来代替 [EmailAddress],这个正则仅供参考,可以修改为适用自己的正则~~

原文地址:https://www.cnblogs.com/weihanli/p/emailaddressattribute-diff-implement-in-netfx-and-netcore.html