DictAttribute.cs 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. namespace Admin.NET.Core;
  7. /// <summary>
  8. /// 字典值合规性校验特性
  9. /// </summary>
  10. [SuppressSniffer]
  11. [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field, AllowMultiple = true, Inherited = true)]
  12. public class DictAttribute : ValidationAttribute, ITransient
  13. {
  14. /// <summary>
  15. /// 字典值合规性校验特性
  16. /// </summary>
  17. /// <param name="dictTypeCode"></param>
  18. /// <param name="errorMessage"></param>
  19. public DictAttribute(string dictTypeCode, string errorMessage = "字典值不合法!")
  20. {
  21. DictTypeCode = dictTypeCode;
  22. ErrorMessage = errorMessage;
  23. }
  24. /// <summary>
  25. /// 字典值合规性校验
  26. /// </summary>
  27. /// <param name="value"></param>
  28. /// <param name="validationContext"></param>
  29. /// <returns></returns>
  30. protected override ValidationResult IsValid(object? value, ValidationContext validationContext)
  31. {
  32. var valueAsString = value?.ToString();
  33. // 判断是否允许空值
  34. if (AllowNullValue && value == null) return ValidationResult.Success;
  35. // 是否忽略空字符串
  36. if (AllowEmptyStrings && string.IsNullOrEmpty(valueAsString)) return ValidationResult.Success;
  37. var sysDictDataServiceProvider = App.GetRequiredService<SysDictDataService>();
  38. var dictDataList = sysDictDataServiceProvider.GetDataList(DictTypeCode).Result;
  39. // 使用HashSet来提高查找效率
  40. var dictCodes = new HashSet<string>(dictDataList.Select(u => u.Code));
  41. if (!dictCodes.Contains(valueAsString))
  42. return new ValidationResult($"提示:{ErrorMessage}|字典【{DictTypeCode}】不包含【{valueAsString}】!");
  43. else
  44. return ValidationResult.Success;
  45. }
  46. /// <summary>
  47. /// 字典编码
  48. /// </summary>
  49. public string DictTypeCode { get; set; }
  50. /// <summary>
  51. /// 是否允许空字符串
  52. /// </summary>
  53. public bool AllowEmptyStrings { get; set; } = false;
  54. /// <summary>
  55. /// 允许空值,有值才验证,默认 false
  56. /// </summary>
  57. public bool AllowNullValue { get; set; } = false;
  58. }