LogNetFileSize.cs 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.IO;
  6. namespace HslCommunication.LogNet
  7. {
  8. /// <summary>
  9. /// 根据文件的大小来存储日志信息
  10. /// </summary>
  11. public class LogNetFileSize : LogNetBase, ILogNet
  12. {
  13. #region 构造方法
  14. /// <summary>
  15. /// 实例化一个根据文件大小生成新文件的
  16. /// </summary>
  17. /// <param name="filePath">日志文件的保存路径</param>
  18. /// <param name="fileMaxSize">每个日志文件的最大大小,默认2M</param>
  19. public LogNetFileSize(string filePath, int fileMaxSize = 2 * 1024 * 1024)
  20. {
  21. m_filePath = filePath;
  22. m_fileMaxSize = fileMaxSize;
  23. LogSaveMode = LogNetManagment.LogSaveModeByFileSize;
  24. m_filePath = CheckPathEndWithSprit(m_filePath);
  25. }
  26. #endregion
  27. /// <summary>
  28. /// 当前正在存储的文件名称
  29. /// </summary>
  30. private string m_fileName = string.Empty;
  31. private string m_filePath = string.Empty;
  32. private int m_fileMaxSize = 2 * 1024 * 1024; //2M
  33. private int m_CurrentFileSize = 0;
  34. /// <summary>
  35. /// 获取需要保存的日志文件
  36. /// </summary>
  37. /// <returns></returns>
  38. protected override string GetFileSaveName()
  39. {
  40. //路径没有设置则返回空
  41. if (string.IsNullOrEmpty(m_filePath)) return string.Empty;
  42. if(string.IsNullOrEmpty(m_fileName))
  43. {
  44. //加载文件名称
  45. m_fileName = GetLastAccessFileName();
  46. }
  47. if(File.Exists(m_fileName))
  48. {
  49. FileInfo fileInfo = new FileInfo(m_fileName);
  50. if (fileInfo.Length > m_fileMaxSize)
  51. {
  52. //新生成文件
  53. m_fileName = GetDefaultFileName();
  54. }
  55. }
  56. return m_fileName;
  57. }
  58. /// <summary>
  59. /// 获取之前保存的日志文件
  60. /// </summary>
  61. /// <returns></returns>
  62. private string GetLastAccessFileName()
  63. {
  64. foreach (var m in GetExistLogFileNames())
  65. {
  66. FileInfo fileInfo = new FileInfo(m);
  67. if (fileInfo.Length < m_fileMaxSize)
  68. {
  69. m_CurrentFileSize = (int)fileInfo.Length;
  70. return m;
  71. }
  72. }
  73. //返回一个新的默认当前时间的日志名称
  74. return GetDefaultFileName();
  75. }
  76. /// <summary>
  77. /// 获取一个新的默认的文件名称
  78. /// </summary>
  79. /// <returns></returns>
  80. private string GetDefaultFileName()
  81. {
  82. //返回一个新的默认当前时间的日志名称
  83. return m_filePath + LogNetManagment.LogFileHeadString + DateTime.Now.ToString("yyyyMMddHHmmss") + ".txt";
  84. }
  85. /// <summary>
  86. /// 返回所有的日志文件
  87. /// </summary>
  88. /// <returns></returns>
  89. public string[] GetExistLogFileNames()
  90. {
  91. if (!string.IsNullOrEmpty(m_filePath))
  92. {
  93. return Directory.GetFiles(m_filePath, LogNetManagment.LogFileHeadString + "*.txt");
  94. }
  95. else
  96. {
  97. return new string[] { };
  98. }
  99. }
  100. }
  101. }