BaseClearServicce.cs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. using Microsoft.Extensions.Hosting;
  2. using Serilog;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. namespace DW5S.WebApi
  9. {
  10. /// <summary>
  11. /// 基础清理服务(负责upload目录的清理,不会清理NotClear目录及其文件)
  12. /// </summary>
  13. public class BaseClearService : BackgroundService
  14. {
  15. private readonly string dir = "upload";
  16. private readonly ILogger logger;
  17. /// <summary>
  18. ///
  19. /// </summary>
  20. /// <param name="logger"></param>
  21. public BaseClearService(ILogger logger)
  22. {
  23. this.logger = logger;
  24. }
  25. /// <summary>
  26. ///
  27. /// </summary>
  28. /// <param name="stoppingToken"></param>
  29. /// <returns></returns>
  30. protected override async Task ExecuteAsync(CancellationToken stoppingToken)
  31. {
  32. await Task.Delay(5000, stoppingToken);//延迟一会儿让webbapi先启动
  33. logger.Information($"启动通用目录{dir}数据清理功能...");
  34. await Task.Run(async () =>
  35. {
  36. while (!stoppingToken.IsCancellationRequested)
  37. {
  38. Clear();
  39. //5分钟扫描一次
  40. await Task.Delay(600 * 1000, stoppingToken);
  41. }
  42. //程序退出时强制删除所有
  43. try
  44. {
  45. Directory.Delete(dir, true);
  46. }
  47. catch
  48. { }
  49. }, stoppingToken);
  50. }
  51. private void Clear()
  52. {
  53. #region 清理空目录
  54. string clearDir = Path.Combine(AppContext.BaseDirectory, dir);
  55. try
  56. {
  57. var dirs = Directory.EnumerateDirectories(clearDir, "*", SearchOption.AllDirectories);
  58. foreach (var item in dirs)
  59. {
  60. if (item.ToLower().Contains("notclear")) continue;
  61. DirectoryInfo dir = new DirectoryInfo(item);
  62. if (dir.EnumerateFiles().Any()) continue;
  63. //删除5分钟以前创建的空目录
  64. if ((DateTime.Now - dir.CreationTime).TotalMinutes > 5)
  65. {
  66. dir.Delete();
  67. }
  68. }
  69. }
  70. catch (Exception ex)
  71. {
  72. logger.Error(ex, $"删除{dir}目录中的空目录出错");
  73. }
  74. #endregion
  75. #region 清理30分钟以前上传的文件
  76. var files = Directory.EnumerateFiles(clearDir, "*", SearchOption.AllDirectories);
  77. foreach (var item in files)
  78. {
  79. if (item.ToLower().Contains("notclear")) continue;
  80. FileInfo f = new FileInfo(item);
  81. if ((DateTime.Now - f.LastWriteTime).TotalMinutes > 30)
  82. {
  83. try
  84. {
  85. f.Delete();
  86. }
  87. catch (Exception ex)
  88. {
  89. logger.Error(ex, $"$删除{dir}目录中文件[{f.Name}]失败");
  90. }
  91. }
  92. }
  93. #endregion
  94. }
  95. }
  96. }