Logger.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. using System;
  2. using System.IO;
  3. using System.Reflection;
  4. namespace LJLib.Tools.File
  5. {
  6. internal class Logger : ILogger
  7. {
  8. private string _path;
  9. private string _filename = "log.txt";
  10. private object _syncRoot = new object();
  11. public Logger()
  12. {
  13. _path = System.IO.Path.GetDirectoryName(Assembly.GetExecutingAssembly().GetName().CodeBase).Replace("file:\\", "");
  14. }
  15. public Logger(string path)
  16. {
  17. _path = path;
  18. }
  19. public Logger(string path, string filename)
  20. {
  21. _path = path;
  22. _filename = filename;
  23. }
  24. public virtual string Path
  25. {
  26. get { return _path; }
  27. }
  28. public virtual string FileName
  29. {
  30. get { return _filename; }
  31. set { _filename = value; }
  32. }
  33. public virtual string FullName
  34. {
  35. get { return _path + "\\" + _filename; }
  36. }
  37. public virtual void WriteLog(string msg)
  38. {
  39. try
  40. {
  41. FileInfo file = new FileInfo(FullName);
  42. if (file.Exists && file.Length > 10240000)
  43. {
  44. string tmpfile = FullName + ".tmp";
  45. using (FileStream fs = file.Open(FileMode.Open, FileAccess.Read))
  46. using (StreamReader reader = new StreamReader(fs))
  47. {
  48. fs.Seek(-1024000, SeekOrigin.End);
  49. reader.ReadLine();
  50. using (StreamWriter sw = System.IO.File.AppendText(tmpfile))
  51. {
  52. while (!reader.EndOfStream)
  53. {
  54. string strline = reader.ReadLine();
  55. sw.WriteLine(strline);
  56. }
  57. sw.Flush();
  58. sw.Close();
  59. }
  60. }
  61. file.Delete();
  62. System.IO.File.Move(tmpfile, FullName);
  63. }
  64. using (StreamWriter sw = System.IO.File.AppendText(FullName))
  65. {
  66. string rslt = "//====================================================================\r\n";
  67. rslt += "// 时间: " + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "\r\n";
  68. rslt += "//--------------------------------------------------------------------\r\n";
  69. rslt += "// " + msg.Replace("\r\n", "\r\n// ") + "\r\n";
  70. rslt += "//====================================================================\r\n\r\n";
  71. sw.Write(rslt);
  72. sw.Flush();
  73. sw.Close();
  74. }
  75. }
  76. catch (System.Exception ex)
  77. {
  78. }
  79. }
  80. public virtual void InsertLog(string msg)
  81. {
  82. try
  83. {
  84. using (FileStream fs = System.IO.File.Open(FullName, FileMode.OpenOrCreate))
  85. {
  86. StreamReader reader = new StreamReader(fs);
  87. string filestr = reader.ReadToEnd();
  88. filestr = DateTime.Now.ToString("yyyy-MM-dd HH:mm") + " " + msg + "\r\n" + filestr;
  89. fs.Seek(0, SeekOrigin.Begin);
  90. StreamWriter writer = new StreamWriter(fs);
  91. writer.Write(filestr);
  92. writer.Flush();
  93. }
  94. }
  95. catch (System.Exception ex)
  96. {
  97. }
  98. }
  99. public virtual bool IsSynchronized
  100. {
  101. get
  102. {
  103. return false;
  104. }
  105. }
  106. public virtual object SyncRoot
  107. {
  108. get
  109. {
  110. return _syncRoot;
  111. }
  112. }
  113. public static Logger Synchronized(Logger logger)
  114. {
  115. return new SyncLogger(logger);
  116. }
  117. }
  118. }