LogHelper.cs 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  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. Console.WriteLine(ex.Message);
  104. }
  105. }
  106. public static void WriteErrLog(Exception ex)
  107. {
  108. string sMsg = string.Format("[消息]:{0}\r\n[跟踪]:{1}", ex.Message, ex.StackTrace);
  109. //mErrLog.Info(sMsg);
  110. AddLog(LogType.Error, ex.Message);
  111. }
  112. /// <summary>
  113. /// 增加日志 1:普通日志 2:警告日志 3:http错误日志 4:奔溃日志 5:MQ消息日志
  114. /// </summary>
  115. /// <param name="msg"></param>
  116. public static void AddLog(LogType logType,string msg)
  117. {
  118. string filetype = "info_";
  119. string msgTitle = "";
  120. switch (logType)
  121. {
  122. case LogType.Normal:
  123. msgTitle = " INFO ";
  124. filetype = "info_";
  125. break;
  126. case LogType.Error:
  127. msgTitle = " ERROR ";
  128. filetype = "error_";
  129. break;
  130. case LogType.HttpError:
  131. msgTitle = " HTTP_ERRO ";
  132. filetype = "httperror_";
  133. break;
  134. case LogType.Mq:
  135. msgTitle = " MQ ";
  136. filetype = "mq_";
  137. break;
  138. case LogType.MqError:
  139. msgTitle = " MQ_ERROR ";
  140. filetype = "mq_";
  141. break;
  142. case LogType.Crash:
  143. msgTitle = " CRASH ";
  144. filetype = "crash_";
  145. break;
  146. }
  147. msg = msgTitle + GetStack() + " " + msg;
  148. AddLog(filetype ,msg);
  149. if(logType == LogType.Error || logType == LogType.HttpError || logType == LogType.MqError)
  150. {
  151. //ReceiveErrorLog?.Invoke(logType, msg);
  152. }
  153. }
  154. public static string GetStack()
  155. {
  156. StackTrace trace = new StackTrace();
  157. //获取是那个类来调用的
  158. string classname = trace.GetFrame(2).GetMethod().DeclaringType.Name;
  159. //获取是那个类中的方法调用的
  160. string method = trace.GetFrame(2).GetMethod().ToString();
  161. return $"{classname} [{method}]";
  162. }
  163. // 在 System.Reflection命名空间下的 MethodBase类
  164. //该类 提供有关方法和构造函数的信息。
  165. //GetCurrentMethod() 是一个静态方法,从一个执行方法中调用,且会返回有关该方法的信息。
  166. //表示当前的执行方法的 MethodBase 对象。
  167. //public static System.Reflection.MethodBase GetCurrentMethod();
  168.    // 1.获取当前执行方法的类名
  169. //System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name;
  170.    // 2.获取当前成员的名称
  171. //System.Reflection.MethodBase.GetCurrentMethod().Name;
  172. ////////////////////////////////////////////////////////////////////////////////
  173. }
  174. }