一、Log4Net的WinForm使用

1、首先使用nuget 添加log4Net 到WinForm项目中

log4j每个符号的具体含义:%d %5p %c{1}:%L - %m%n

log4j.properties

#  %m 输出代码中指定的消息
# %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
# %r 输出自应用启动到输出该log信息耗费的毫秒
# %c 输出所属的类目,通常就是所在类的全名
# %t 输出产生该日志事件的线程名
# %n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
# %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
# %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。
log4j.appender.stdout.layout.ConversionPattern=%d [%t] %-5p %c - %m%n #日志文件 每日
log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A1.File=F:/mylog.txt
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
#%时间 [%线程] %log级别 %完整类名 - %消息 %换行
log4j.appender.A1.layout.ConversionPattern=%d [%t] %-5p %c - %m%n

2、在WinForm项目的App.config中添加下面内容(只要是设置日志的添加类型,路径等)

<log4net>
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="Log\Log.txt" />
<param name="AppendToFile" value="true" />
<param name="MaxSizeRollBackups" value="100" />
<param name="MaximumFileSize" value="2MB" />
<param name="RollingStyle" value="Size" />
<param name="StaticLogFileName" value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%-15p %d [%c] %m%n" />
</layout>
</appender>
<root>
<level value="all" />
<appender-ref ref="RollingLogFileAppender" />
</root>
</log4net>

3、在WinForm项目的Properties中的AssemblyInfo.cs中添加下面内容

[assembly: log4net.Config.DOMConfigurator(Watch = true)](不建议使用,已经过时了)
[assembly: log4net.Config.XmlConfigurator(ConfigFileExtension = "config", Watch = true)]

4、在WinForm项目启动项项目中使用

static class Program
{
public static log4net.ILog LOG = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
/// <summary>
/// 应用程序的主入口点。
/// </summary>
[STAThread]
static void Main()
{
//捕获未处理异常
Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException);
Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException);
AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException);

Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(false);
Application.Run(new Form1());
}

static void Application_ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e)
{
LOG.Error(e.Exception);
//throw new Exception("线程未知异常", e.Exception);
MessageBox.Show(e.Exception.Message, "线程异常", MessageBoxButtons.OK, MessageBoxIcon.Error);
Application.Exit();
}

static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
{
Exception ex = e.ExceptionObject as Exception;
LOG.Error(ex);
MessageBox.Show(ex.Message, "应用程序异常", MessageBoxButtons.OK, MessageBoxIcon.Error);
Application.Exit();
}
}

最新文章

  1. Missing artifact com.oracle:ojdbc14:jar:10.2.0.4.0
  2. fastcgi 性能初配 504 gateway time-out
  3. EffectiveJava——请不要在代码中使用原生态类型
  4. Slave2: no datanode to stop(HADOOP_PID_DIR)
  5. [Leetcode] Interleaving String
  6. Qt中使用ActiveX(3篇)
  7. PDT已有很大改进
  8. 通过桥接虚拟网卡使VMWare和宿主机实现双向通讯
  9. 牛课--C/C++
  10. whereis 命令
  11. Android Activity切换动画overridePendingTransition
  12. Web classPath
  13. 阿里云轻量应用服务器Lamp部署php工程踩过的坑
  14. Linux命令基础2-ls命令
  15. JavaScript:event loop详解
  16. 高效的 JavaScript
  17. 从零开始学 Web 之 CSS3(七)多列布局,伸缩布局
  18. [SQL]197. Rising Temperature
  19. (转)drbd详解
  20. 微信小程序 request请求封装

热门文章

  1. C++学习---- static关键字用法总结
  2. Long Short-Term Memory (LSTM)
  3. JAVA的文件操作【转】
  4. HDU 5794 A Simple Chess Lucas定理+dp
  5. jquery用正则表达式验证密码强度
  6. 简明Python3教程 1.介绍
  7. el-input怎么绑定回车事件
  8. 洛谷 P2501 [HAOI2006]数字序列 解题报告
  9. HDU 2844 二进制优化的多重背包
  10. [bzoj 2733]启发式合并权值线段树