IsEmailAttribute.cs 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. using DnsClient;
  2. using Masuit.Tools.Config;
  3. using System.ComponentModel.DataAnnotations;
  4. using System.Linq;
  5. using System.Net;
  6. using System.Text.RegularExpressions;
  7. namespace Masuit.Tools.Core.Validator
  8. {
  9. /// <summary>
  10. /// 邮箱校验
  11. /// </summary>
  12. public class IsEmailAttribute : ValidationAttribute
  13. {
  14. private readonly bool _valid;
  15. /// <summary>
  16. /// 域白名单
  17. /// </summary>
  18. private string WhiteList { get; }
  19. /// <summary>
  20. /// 域黑名单
  21. /// </summary>
  22. private string BlockList { get; }
  23. /// <summary>
  24. /// 可在配置文件AppSetting节中添加EmailDomainWhiteList配置邮箱域名白名单,EmailDomainBlockList配置邮箱域名黑名单,英文分号(;)或感叹号(!)或逗号(,)分隔,每个单独的元素支持正则表达式
  25. /// </summary>
  26. /// <param name="valid">是否检查邮箱的有效性</param>
  27. public IsEmailAttribute(bool valid = true)
  28. {
  29. WhiteList = Regex.Replace(ConfigHelper.GetConfigOrDefault("EmailDomainWhiteList"), @"(\w)\.([a-z]+),?", @"$1\.$2!").Trim('!');
  30. BlockList = Regex.Replace(ConfigHelper.GetConfigOrDefault("EmailDomainBlockList"), @"(\w)\.([a-z]+),?", @"$1\.$2!").Trim('!');
  31. _valid = valid;
  32. }
  33. /// <summary>
  34. /// 邮箱校验
  35. /// </summary>
  36. /// <param name="value"></param>
  37. /// <returns></returns>
  38. public override bool IsValid(object value)
  39. {
  40. if (value == null)
  41. {
  42. ErrorMessage = "邮箱不能为空!";
  43. return false;
  44. }
  45. var email = (string)value;
  46. if (email.Length < 7)
  47. {
  48. ErrorMessage = "您输入的邮箱格式不正确!";
  49. return false;
  50. }
  51. if (email.Length > 256)
  52. {
  53. ErrorMessage = "您输入的邮箱无效,请使用真实有效的邮箱地址!";
  54. return false;
  55. }
  56. if (!string.IsNullOrEmpty(BlockList) && BlockList.Split('!', ';').Any(item => Regex.IsMatch(email, item)))
  57. {
  58. ErrorMessage = "您输入的邮箱无效,请使用真实有效的邮箱地址!";
  59. return false;
  60. }
  61. if (!string.IsNullOrEmpty(WhiteList) && WhiteList.Split('!').Any(item => Regex.IsMatch(email, item)))
  62. {
  63. return true;
  64. }
  65. var isMatch = email.MatchEmail().isMatch;
  66. if (isMatch && _valid)
  67. {
  68. var nslookup = new LookupClient();
  69. var records = nslookup.Query(email.Split('@')[1], QueryType.MX).Answers.MxRecords().ToList();
  70. if (!string.IsNullOrEmpty(BlockList) && records.Any(r => BlockList.Split('!').Any(item => Regex.IsMatch(r.Exchange.Value, item))))
  71. {
  72. ErrorMessage = "您输入的邮箱无效,请使用真实有效的邮箱地址!";
  73. return false;
  74. }
  75. var task = records.SelectAsync(r => Dns.GetHostAddressesAsync(r.Exchange.Value).ContinueWith(t =>
  76. {
  77. if (t.IsCanceled || t.IsFaulted)
  78. {
  79. return new[] { IPAddress.Loopback };
  80. }
  81. return t.Result;
  82. }));
  83. isMatch = task.Result.SelectMany(a => a).Any(ip => !ip.IsPrivateIP());
  84. }
  85. if (isMatch)
  86. {
  87. return true;
  88. }
  89. ErrorMessage = "您输入的邮箱格式不正确!";
  90. return false;
  91. }
  92. }
  93. }