LogHelper.cs 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.IO;
  5. using System.Linq;
  6. using System.Text;
  7. namespace MeterVision.Util
  8. {
  9. public class LogHelper
  10. {
  11. public static Action<LogType, string> ReceiveErrorLog;
  12. /// <summary>
  13. /// 限制文件生成大小,258000字节,大约253kb
  14. /// </summary>
  15. private const long fileBytes = 258000;
  16. private static string GetNewFileName(string fileFolderPath,string filetype ,string fileNameNoExtension)
  17. {
  18. string fileName = string.Empty;
  19. if (fileNameNoExtension.LastIndexOf('_') == -1)
  20. {
  21. int index = 1;
  22. fileName = fileFolderPath + "\\" + filetype + DateTime.Now.ToString("yyyy-MM-dd") + "_" + index + ".txt";
  23. while (File.Exists(fileName))
  24. {
  25. if (File.ReadAllBytes(fileName).Length < fileBytes)
  26. {
  27. break;
  28. }
  29. index++;
  30. fileName = fileFolderPath + "\\" + filetype + DateTime.Now.ToString("yyyy-MM-dd") + "_" + index + ".txt";
  31. }
  32. }
  33. else
  34. {
  35. int index = 1;
  36. int.TryParse(fileNameNoExtension.Split('_')[2], out index);
  37. if (index == 0)
  38. {
  39. index = 1;
  40. }
  41. fileName = fileFolderPath + "\\" + filetype + DateTime.Now.ToString("yyyy-MM-dd") + "_" + index + ".txt";
  42. while (File.Exists(fileName))
  43. {
  44. if (File.ReadAllBytes(fileName).Length < fileBytes)
  45. {
  46. break;
  47. }
  48. index++;
  49. fileName = fileFolderPath + "\\" + filetype + DateTime.Now.ToString("yyyy-MM-dd") + "_" + index + ".txt";
  50. }
  51. }
  52. return fileName;
  53. }
  54. /// <summary>
  55. /// 日志记录,在程序执行的根目录,写入txt文件,文件固定大小,超过限定大小自动创建新日志文件
  56. /// </summary>
  57. /// <param name="msg">记录内容</param>
  58. /// <returns></returns>
  59. private static void AddLog(string filetype,string msg)
  60. {
  61. string saveFolder = "Log";//日志文件保存路径
  62. try
  63. {
  64. string fileFolderPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, saveFolder);
  65. if (Directory.Exists(fileFolderPath) == false)
  66. {
  67. Directory.CreateDirectory(fileFolderPath);
  68. }
  69. string fileName = string.Empty;
  70. string[] files = Directory.GetFiles(fileFolderPath, filetype + "*");
  71. if (files.Length == 0)
  72. {
  73. fileName = fileFolderPath + "\\" + filetype + DateTime.Now.ToString("yyyy-MM-dd") + "_1.txt";
  74. //goto DO_WRITE;
  75. }
  76. else
  77. {
  78. string[] files2 = files.OrderByDescending(x => x).ToArray();
  79. FileInfo fileInfo = new FileInfo(files2[0]);
  80. string fileNameNoExtension = Path.GetFileNameWithoutExtension(fileInfo.Name);
  81. if (fileInfo.Length > fileBytes)
  82. {
  83. fileName = GetNewFileName(fileFolderPath,filetype,fileNameNoExtension);
  84. }
  85. else
  86. {
  87. fileName = GetNewFileName(fileFolderPath,filetype,fileNameNoExtension);
  88. }
  89. }
  90. //DO_WRITE:
  91. FileStream fs = new FileStream(fileName, FileMode.Append);
  92. string time = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff");
  93. msg = time + ">" + msg + System.Environment.NewLine;
  94. byte[] logBytes = UTF8Encoding.UTF8.GetBytes(msg);
  95. fs.Write(logBytes, 0, logBytes.Length);
  96. fs.Flush();
  97. fs.Close();
  98. fs.Dispose();
  99. // tishiMsg = "写入日志成功";
  100. }
  101. catch (Exception ex)
  102. {
  103. }
  104. }
  105. public static void WriteErrLog(Exception ex)
  106. {
  107. string sMsg = string.Format("[消息]:{0}\r\n[跟踪]:{1}", ex.Message, ex.StackTrace);
  108. //mErrLog.Info(sMsg);
  109. AddLog(LogType.Error, ex.Message);
  110. }
  111. /// <summary>
  112. /// 增加日志 1:普通日志 2:警告日志 3:http错误日志 4:奔溃日志 5:MQ消息日志
  113. /// </summary>
  114. /// <param name="msg"></param>
  115. public static void AddLog(LogType logType,string msg)
  116. {
  117. string filetype = "info_";
  118. string msgTitle = "";
  119. switch (logType)
  120. {
  121. case LogType.Normal:
  122. msgTitle = " INFO ";
  123. filetype = "info_";
  124. break;
  125. case LogType.Error:
  126. msgTitle = " ERROR ";
  127. filetype = "error_";
  128. break;
  129. case LogType.HttpError:
  130. msgTitle = " HTTP_ERRO ";
  131. filetype = "httperror_";
  132. break;
  133. case LogType.Mq:
  134. msgTitle = " MQ ";
  135. filetype = "mq_";
  136. break;
  137. case LogType.MqError:
  138. msgTitle = " MQ_ERROR ";
  139. filetype = "mq_";
  140. break;
  141. case LogType.Crash:
  142. msgTitle = " CRASH ";
  143. filetype = "crash_";
  144. break;
  145. }
  146. msg = msgTitle + GetStack() + " " + msg;
  147. AddLog(filetype ,msg);
  148. if(logType == LogType.Error || logType == LogType.HttpError || logType == LogType.MqError)
  149. {
  150. //ReceiveErrorLog?.Invoke(logType, msg);
  151. }
  152. }
  153. public static string GetStack()
  154. {
  155. StackTrace trace = new StackTrace();
  156. //获取是那个类来调用的
  157. string classname = trace.GetFrame(2).GetMethod().DeclaringType.Name;
  158. //获取是那个类中的方法调用的
  159. string method = trace.GetFrame(2).GetMethod().ToString();
  160. return $"{classname} [{method}]";
  161. }
  162. // 在 System.Reflection命名空间下的 MethodBase类
  163. //该类 提供有关方法和构造函数的信息。
  164. //GetCurrentMethod() 是一个静态方法,从一个执行方法中调用,且会返回有关该方法的信息。
  165. //表示当前的执行方法的 MethodBase 对象。
  166. //public static System.Reflection.MethodBase GetCurrentMethod();
  167.    // 1.获取当前执行方法的类名
  168. //System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name;
  169.    // 2.获取当前成员的名称
  170. //System.Reflection.MethodBase.GetCurrentMethod().Name;
  171. ////////////////////////////////////////////////////////////////////////////////
  172. }
  173. }