DataMaskAttribute.cs 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  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. [AttributeUsage(AttributeTargets.Property)]
  11. public class DataMaskAttribute : Attribute
  12. {
  13. /// <summary>
  14. /// 脱敏起始位置(从0开始)
  15. /// </summary>
  16. private int StartIndex { get; }
  17. /// <summary>
  18. /// 脱敏长度
  19. /// </summary>
  20. private int Length { get; }
  21. /// <summary>
  22. /// 脱敏字符(默认*)
  23. /// </summary>
  24. private char MaskChar { get; set; } = '*';
  25. /// <summary>
  26. /// 是否保留原始长度(默认true)
  27. /// </summary>
  28. private bool KeepLength { get; set; } = true;
  29. public DataMaskAttribute(int startIndex, int length)
  30. {
  31. if (startIndex < 0) throw new ArgumentOutOfRangeException(nameof(startIndex));
  32. if (length <= 0) throw new ArgumentOutOfRangeException(nameof(length));
  33. StartIndex = startIndex;
  34. Length = length;
  35. }
  36. /// <summary>
  37. /// 执行脱敏处理
  38. /// </summary>
  39. public string Mask(string input)
  40. {
  41. if (string.IsNullOrEmpty(input) || input.Length <= StartIndex)
  42. return input;
  43. var maskedLength = Math.Min(Length, input.Length - StartIndex);
  44. var maskStr = new string(MaskChar, KeepLength ? maskedLength : Math.Min(4, maskedLength));
  45. return input.Substring(0, StartIndex) + maskStr +
  46. (StartIndex + maskedLength < input.Length ?
  47. input.Substring(StartIndex + maskedLength) : "");
  48. }
  49. }