好记性不如烂笔头,这次是由衷的感受到了!

  log4net 是一个很好用的日志记录工具,引用入项目中,如何查看项目内部运行情况,如何快速定位异常信息,好的日志记录能帮很大的忙;

  log4net 很好用,快速上手,配置简单,可是 (捂脸)自己配置就是配不上啊!!!!因为不想解读源码,只想快速配置好进行读取记录,哎,难死了。。。。。。

  但是功夫不负有心人,只要功夫深,铁棒磨成针!在自己坚持之下,终于配置完成了,能够生成日志,进行查看了! 不说了,开始记录:

  一、单项目单独使用

   1、 准备 log4net.dll(或者在 Vs  中搜索Nuget 程序包,下载 log4net 管理包)添加引用。

    

    

  2、引用完成之后,项目引用中有显示刚才操作dll

    

    3、添加AssemblyInfo 资源信息;(  [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", ConfigFileExtension = "config", Watch = true)]  )

     

      4、添加log4net.config文件,右键 ---》编辑文件属性:始终复制(一般.config 文件系统会默认始终复制属性,防止特殊情况,检查处理一下。)    

      

<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
</configSections>
<log4net>
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
<!--日志存放位置 ~/..-->
<file value="log\" />
<!--文件命名方式-->
<datePattern value="yyyy-MM-dd&quot;.txt&quot;" />
<!--追加到文本末尾-->
<appendToFile value="true" />
<rollingStyle value="Date" />
<staticLogFileName value="false" />
<maxSizeRollBackups value="20" />
<!--最多产生的日志文件数,超过则只保留最新的n个。设定值value="-1"为不限文件数-->
<param name="MaxSizeRollBackups" value="30" />
<layout type="log4net.Layout.PatternLayout">
<!--%n日志时间:%d [%t] %n日志级别:%-5p %n消息描述:%c [%x] %n%m %n-->
<!--%n异常时间:%d [%t] %n异常级别:%-5p %n异常位置:[%thread] 代码位置(%file:%line) %n消息描述:%message%n异常:%exception%n%n-->
<param name="ConversionPattern" value="%d [%thread] %-5p %message (%file:%line) %n" />
</layout>
</appender>
  <!--识别的log4net配置名称-->
<logger name="loginfo">
<level value="ALL" />
<appender-ref ref="RollingLogFileAppender" />
</logger>
</log4net>
</configuration>

     4、项目使用测试!

      

      

    二、封装log4net 到公用帮助类库中      

      1、在公用帮助类库中,添加 log4net.dll 引用,引用方式同上;

      2、在公用帮助类库中,添加资源引用 AssemblyInfo.cs  添加log4net.config  配置读取信息;方式同上添加方式。

      

      3、封装Log4net  帮助类(LoggerHelper.cs) --看需要自己拓展      

using log4net;
using System;
public class LogerHelper
{
#region
private static ILog _LoggerInfo;
private static ILog LogInfo
{
get
{
if (_LoggerInfo == null)
{
_LoggerInfo = log4net.LogManager.GetLogger("loginfo");
}
return _LoggerInfo;
}
set
{
value = _LoggerInfo;
}
}
#endregion public LogerHelper(Type type)
{
LogInfo = LogManager.GetLogger(type);
} static LogerHelper()
{ } public static void SetConfig()
{
log4net.Config.XmlConfigurator.Configure();
} public static void SetConfig(FileInfo configFile)
{
log4net.Config.XmlConfigurator.Configure(configFile);
} /// <summary>
/// Log4日志Error
/// </summary>
/// <param name="msg"></param>
/// <param name="ex"></param>
public static void Error(Exception ex = null)
{
Error("出现异常!", ex);
} /// <summary>
/// Log4日志
/// </summary>
/// <param name="msg"></param>
/// <param name="ex"></param>
public static void Error(string msg = "出现异常", Exception ex = null)
{
try
{
if (LogInfo.IsErrorEnabled)
{
LogInfo.Error(msg, ex);
}
}
catch { }
} /// <summary>
/// Log4日志Warn
/// </summary>
/// <param name="msg"></param>
public static void Warn(string msg)
{
//Console.WriteLine(msg);
LogInfo.Warn(msg);
} /// <summary>
/// Log4日志Info
/// </summary>
/// <param name="msg"></param>
public static void Info(string msg)
{
//Console.WriteLine(msg);
LogInfo.Info(msg);
} /// <summary>
/// Log4日志Debug
/// </summary>
/// <param name="msg"></param>
public static void Debug(string msg)
{
//Console.WriteLine(msg);
LogInfo.Debug(msg);
}
}

      4、工具类封装loghelper 后,在输出/展示应用程序中,需要添加 log4net.config  文件,如果不添加,将不会记录日志:

       比如我要在 console 控制台应用程序中使用日志,使用log4net 记录输出日志时,需要在console 应用程序中添加 log4net.config 文件。

      

      

      5、日志样例:

      

    三、总结

    1、引用log4net.dll 后,看在哪使用,如果单独使用,在当前应用程序的资源文件AssemblyInfo.cs 中添加 ;

      (如果你有公用的工具类库,放置封装log4net 的Helper信息时,在log4netHelper  所在应用程序资源文件AssemblyInfo.cs 中添加 ),

      [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", ConfigFileExtension = "config", Watch = true)]

    2、在最终的输出应用程序中添加 log4net.config,设置文件属性为始终复制;

    3、log4net.config  中内容记录展示样式:(log4net.Layout.PatternLayout --》ConversionPattern 配置)

%m[%message] : 输出的日志消息
%n : 换行
%d[%datetime] : 输出当前语句运行的时刻
%r : 输出程序从运行到执行到当前语句时消耗的毫秒数
%d : 当前语句所在的线程ID
%p : 日志的当前优先级别
%c :当前日志对象的名称
%L : 输出语句所在的行号
%F :输出语句所在的文件名
%-数字 :表示该项的最小长度,如果不够,则用空格填充

   本文log4net.config  文件满足一般需要,想配置更多,功能更全,建议了解一下log4net.Config 节点参数。

   配置到类库中进行调用参考:http://grim1980.blog.sohu.com/255519333.html

   配置文件log4net.config  配置内容解说:https://www.cnblogs.com/kissazi2/p/3392605.html

   如有不合理之处,请大家多多指教。

   如果您觉得本文对您有帮助,欢迎点击“收藏”按钮!(/:微笑)欢迎转载,转载请注明出处。

Log4Net 使用及组合公共类的更多相关文章

  1. 一个Java文件至多包含一个公共类

    编写一个java源文件时,该源文件又称为编译单元.一个java文件可以包含多个类,但至多包含一个公共类,作为编译时该java文件的公用接口,公共类的名字和源文件的名字要相同,源文件名字的格式为[公共类 ...

  2. IOS 公共类-MyDateUtil 日期处理Util

    IOS 公共类-MyDateUtil 日期处理Util 此为处理日期的公共类.适用IOS6+ .h文件: #import <Foundation/Foundation.h> //适用 IO ...

  3. IOS 公共类-MyMBProgressUtil Progress显示

    IOS 公共类-MyMBProgressUtil Progress显示 此公共类用于显示提示框,对MBProgress的进一步封装.可以看下面的代码 接口: @interface MyMBProgre ...

  4. 不可或缺 Windows Native (21) - C++: 继承, 组合, 派生类的构造函数和析构函数, 基类与派生类的转换, 子对象的实例化, 基类成员的隐藏(派生类成员覆盖基类成员)

    [源码下载] 不可或缺 Windows Native (21) - C++: 继承, 组合, 派生类的构造函数和析构函数, 基类与派生类的转换, 子对象的实例化, 基类成员的隐藏(派生类成员覆盖基类成 ...

  5. ASP.NET中常用的几个李天平开源公共类LTP.Common,Maticsoft.DBUtility,LtpPageControl

    ASP.NET中常用的几个开源公共类: LTP.Common.dll: 通用函数类库     源码下载Maticsoft.DBUtility.dll 数据访问类库组件     源码下载LtpPageC ...

  6. Java ClassLoader基础及加载不同依赖 Jar 中的公共类

    转载自:最新内容及最清晰格式请见 http://www.trinea.cn/android/java-loader-common-class/ 本文主要介绍 ClassLoader 的基础知识,Cla ...

  7. ASP.NET中常用的几个李天平开源公共类LTP.Common,Maticsoft.DBUtility,LtpPageControl (转)

    ASP.NET中常用的几个开源公共类: LTP.Common.dll: 通用函数类库     源码下载Maticsoft.DBUtility.dll 数据访问类库组件     源码下载LtpPageC ...

  8. 自己封装的C#操作redis公共类

    关于C#操作redis公共类,网上有很多版本,每个版本我都看了,发觉还是不够完美,都存在一个问题,只能操作单一的缓存数据库 redis指令支持上,这里可以自己去扩展,下面分享下我近期封装的一个redi ...

  9. Android公共库——图片缓存 网络缓存 下拉及底部更多ListView 公共类

    Android公共库——图片缓存 网络缓存 下拉及底部更多ListView 公共类 转载自http://www.trinea.cn/android/android-common-lib/ 介绍总结的一 ...

随机推荐

  1. 修改tomcat的字符集问题

    转 默认情况下,tomcat使用的是iso8859-1的编码编码方式,浏览器的embed标签中src指向的地址要通过tomcat去解析.如果包含中文,采用这种编码方式就会出现乱码问题,而在这种情况下, ...

  2. Hash!

    Panda一个字符串是否是另一个字符串的子串 #include<bits/stdc++.h> using namespace std; const int mod=998244353,tt ...

  3. 154-PHP strpos函数

    <?php $str='passwords'; //定义一个字符串 $position=strpos($str,'s'); //查找字母s第一次出现的位置 echo '字母s的位置是'.$pos ...

  4. Spark 内存管理

    Spark 内存管理 Spark 执行应用程序时, 会启动 Driver 和 Executor 两种 JVM 进程 Driver 负责创建 SparkContext 上下文, 提交任务, task的分 ...

  5. 使用UltraISO(软碟通)制作U盘制作启动盘完整教程

    背景:服务器需要安装系统,但是没有启动盘只有镜像. 前提:U盘和安装镜像准备好 步骤一:首先我们先安装软碟通,完成安装后打开软碟通,文件->打开,打开我们需要制作的iso镜像.如下图(也可下本地 ...

  6. kubernter相关内容

    1. Kubernetes 第一章:互联网架构的演变 随着1946年世界上第一台电子计算机的问世网络就随之出现了,只不过当初只是为了解决多个终端之间的连接,这就是局域网的雏形.后来,随着美国国防部高级 ...

  7. TX2-刷机完成后安装程序ubuntu_linux命令&TX2学习总结

    Linux教程|菜鸟教程:http://www.runoob.com/linux/linux-tutorial.html 认识linux:ping命令:ping命令是常用的网络命令ping网关:pin ...

  8. 关于SI4432的问题简单讲解

    对于SX1278 和SI4432的对比性,下面为大家展示对比参数: 由此可以看出的SI4432虽然跟SX1278有部分地方不同,但是整体来说还是差别不大,各有各的长处和短处,性价比上个人还是觉得SI4 ...

  9. bzoj 4247挂饰

    背包????不会... #include<bits/stdc++.h> #define INF 0x7fffffff #define LL long long #define N 1000 ...

  10. 自学Java第五章——《面向对象基础》

    5.1 类与对象 1.类:一类具有相同特性的事物的抽象描述. 对象:类的一个个体,实例,具体的存在. 类是对象的设计模板. 2.如何声明类? [修饰符] class 类名{    成员列表:属性.方法 ...