在程序发布到服务器上的时候,不能在像本地执行一样可以调试,在发生错误时候,往往不能很方便的查找错误。将错误信息写入文件是一种比较常用的处理方法。以下是一个日志类,实现以下功能:

1)按日期每天生产不同日志文件,方便按照日期来查找日志。

2)按日志类型生产不同的文件,比如 跟踪信息、警告信息、错误信息用不同的日志文件来记录;方便我们查找指定类型的日志。

3)可以指定保持日志文件文件夹,如果不指定日志文件夹,Web应用保持到Bin文件夹,Windows Forms应用保持到.EXE文件所在的文件夹。

4)可以指定日志的前缀

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Web; /// <summary>
/// LogManager 的摘要说明
/// </summary>
/// 1)按日期每天生产不同日志文件,方便按照日期来查找日志。
/// 2)按日志类型生产不同的文件,比如 跟踪信息、警告信息、错误信息用不同的日志文件来记录;方便我们查找指定类型的日志。
/// 3)可以指定保持日志文件文件夹,如果不指定日志文件夹,Web应用保持到Bin文件夹,Windows Forms应用保持到.EXE文件所在的文件夹。
/// 4)可以指定日志文件的前缀。
public class LogManager
{
private static string logPath = string.Empty;
/// <summary>
/// 保存日志的文件夹
/// </summary>
public static string LogPath
{
get
{
if (logPath == string.Empty)
{
if (System.Web.HttpContext.Current == null)
// Windows Forms 应用
logPath = AppDomain.CurrentDomain.BaseDirectory; //根目录
else
// Web 应用
logPath = AppDomain.CurrentDomain.BaseDirectory + @"bin/"; //存放在bin文件夹下
}
return logPath;
}
set { logPath = value; }
} private static string logFielPrefix = string.Empty;
/// <summary>
/// 日志文件前缀
/// </summary>
public static string LogFielPrefix
{
get { return logFielPrefix; }
set { logFielPrefix = value; }
} /// <summary>
/// 写日志
/// </summary>
public static void WriteLog(string logFile, string msg)
{
try
{
System.IO.StreamWriter sw = System.IO.File.AppendText(
LogPath + LogFielPrefix + logFile + "_" +
DateTime.Now.ToString("yyyyMMdd") + ".Log"
);
StringBuilder sb = new StringBuilder();
//sb.Append("---------------------------------------------------------------------");
sb.Append(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss: ") + "错误信息:");
//sb.Append("---------------------------------------------------------------------");
sb.Append(msg);
//sb.Append("---------------------------------------------------------------------");
sw.WriteLine(sb.ToString());
sw.Close();
}
catch(Exception IoEx)
{
WriteLog(LogFile.Error, IoEx.Message.ToString());
}
} /// <summary>
/// 写日志
/// </summary>
public static void WriteLog(LogFile logFile, string msg)
{
WriteLog(logFile.ToString(), msg);
}
} /// <summary>
/// 日志类型
/// </summary>
public enum LogFile
{
Trace, //跟踪文件
Warning,//警告文件
Error,
SQL
}

  调用

LogManager.LogPath = "D://"; //文件目录 不赋值存放在默认位置
LogManager.LogFielPrefix = "02"; //文件前缀
LogManager.WriteLog(LogFile.Trace,"26568235673265874");

  

  

最新文章

  1. poj 1430 Binary Stirling Numbers
  2. ggplot2 legend图例的修改
  3. CI 笔记3 (easyui 和 js 排错)
  4. C语言库函数大全及应用实例四
  5. linux下的外网木马前期要的工具
  6. 随笔︱MRO-Microsoft R Open使用心得与相应内容总结
  7. Linux环境下用C语言实现socket 通信---简单代码
  8. 如何增加Ubuntu交换空间swap
  9. 闲记 单元格与单元格之间的边 ///字体属性都是font开头,除了颜色属性 ///文本属性都是text开的,除了设置行高。
  10. SqlServer 更改数据库名称
  11. Ex 5_33 实现一个关于公式长度(其中所有文字总的出现次数)为线性时间的Horn公式可满足性问题_第十次作业
  12. What is a UINavigationTransitionView
  13. 2018-03-17 handler学习使用
  14. Java基础-逻辑运算符Logic Operators
  15. Inno Setup入门(三)——指定压缩方式
  16. Splash 对象属性
  17. CSS高级布局
  18. win xp firefox,chrome 在浏览网页时字体发虚,可以设置为新宋体
  19. FineReport中JS如何自定义按钮导出
  20. 35. Search Insert Position (Array; Divide-and-Conquer)

热门文章

  1. 【前端优化之渲染优化】大屏android手机动画丢帧的背后
  2. SharePoint 2013 开发教程
  3. shift粘滞键后门创建/复原批处理
  4. 关于case语句中声明变量并初始化的注意事项
  5. SSH面试题(struts2+Spring+hibernate)
  6. ambari2.4.2_centos7 学习全纪录
  7. Mysql 里面使用row_number() 的用法和注意
  8. shell 脚本之判断语句 if 详解
  9. 用ORM的思想操作XML文档,一个对象就搞定不要太简单。滚蛋吧!XmlDocument、XmlNode、Xml***……
  10. 手机app软件开发有什么需要注意的细节?