![]() ![]() |
获取异常的内部信息 |
![]() ![]() |
Overloaded. 将日志写到数据库中[须要配置LogConn项后方生效 ] |
![]() ![]() |
Overloaded. 将日志写到外部txt[web.config中配置路径,配置项为Logpath,默认路径为 "Logs/" ] |
1:这个类很简单,主要的使用方法只有:WriteLogToTxt。web
2:WriteLogToDB这个方法(只是SysLogs的简单封装用法,内部用的较多,后续可能会屏蔽此方法,能够暂不介绍)。数据库
3:GetExceptionMessage只是从Exception里获取字符串,因此没啥好说。svn
static void Main(string[] args) { ExeLog(); // ExeSysLog(); Console.Read(); } static void ExeLog() { AppConfig.Log.IsWriteLog = true; AppConfig.Log.LogPath = "自定义错误日志"; Log.WriteLogToTxt("这是错误信息"); Log.WriteLogToTxt("这是错误信息", LogType.Assert); Log.WriteLogToTxt("这是错误信息", LogType.Debug); Log.WriteLogToTxt("这是错误信息", LogType.Error); Log.WriteLogToTxt("这是错误信息", LogType.Info); Log.WriteLogToTxt("这是错误信息", LogType.Warn); Console.WriteLine("请查看Debug目录"); }
1:AppConfig类对应属性都是能够配置在Web.Config或App.Config,示例代码中直接用代码配置了。优化
2:IsWriteLog要配置为True,才会写文本(不配置默认抛异常,不写日志)。spa
1:SysLogs该类主要用来写数据库日志用(Log类是写文本)。日志
2:须要配置LogConn的数据库连接,若是和默认在同一个数据库,配置LogConn为Conn便可。code
3:实例后用Insert方法便可。blog
static void ExeSysLog() { AppConfig.Log.LogConn = "txt path={0}txtdb";//演示只有用文本数据库来演示了 AppConfig.Log.LogTableName = "MyLogs";//能够更改表名 using (SysLogs sl=new SysLogs())//往数据库里写一条错误日志 { sl.Message = "这是错误信息"; sl.PageUrl = “http://code.taobao.org/svn/cyqopen/trunk/CYQ.Data.GettingStarted/”; sl.UserName = "路过秋天"; sl.LogType = "Sys"; sl.Insert(); List<SysLogs> list = sl.Select<SysLogs>(); Console.WriteLine("如今的有:" + list.Count + "条数据"); } // Log.WriteLogToDB("呵呵", LogType.Error, "cyq");//和使用sysLogs同样。 }
1:须要指定LogConn:数据库对应的连接。ci
2:指定LogTableName:指定表名(不指定则默认表名为SysLogs)字符串
3:若是默认没有对应的表,会自动建立。
4:实例后就是普通ORM的增删改查操做。
5:简化的写法是调用Log.WriteLogToDB。
通过不断的优化各简化后,最终对外的使用方法灰常的简单。
项目的Demo示例源码,用SVN checkout:http://code.taobao.org/svn/cyqopen/trunk/CYQ.Data.GettingStarted/
最后谢谢大伙的支持!