NLog日志封装和配置(C#)

NLog是一个基于.NET平台编写的类库,我们可以使用NLog在应用程序中添加极为完善的跟踪调试代码。
NLog是一个简单灵活的.NET日志记录类库。通过使用NLog,我们可以在任何一种.NET语言中输出带有上下文的(contextual information)调试诊断信息,根据喜好配置其表现样式之后发送到一个或多个输出目标(target)中。

简单的说可以用NLog记录系统中的日志,尤其是项目上线以后在线上如果出现问题,没有日志将很难定位到问题。

NLog下载http://nlog-project.org/download/

下面主要是我在项目中封装的一个日志类,以及NLog的配置文件。

需要引用dll,NLog.dll ,命名空间:

using NLog;
using NLog.Config;

封装的日志类为:

/// 
/// 项目日志封装
/// 
public class Logs
{
    private static Logger logger = LogManager.GetCurrentClassLogger(); //初始化日志类

    /// 
    /// 日志状态枚举
    /// 
    private enum LogState
    {
        /// 
        /// 用户已登录
        /// 
        NLogin,
        /// 
        /// 用户未登录
        /// 
        YLogin,
    }

    /// 
    /// 静态构造函数
    /// 
    static Logs()
    {
        //初始化配置日志
        LogManager.Configuration = new XmlLoggingConfiguration(System.AppDomain.CurrentDomain.BaseDirectory.ToString() + "\\Demo\\NLog.config");
    }

    /// 
    /// 日志写入通用方法(建议使用)
    /// 
    /// 日志内容
    ///  日志类别
    ///     类别: 1.Debug
    ///           2.Info
    ///           3.Error
    ///           4.Fatal
    ///           5.Warn
    /// 
    /// 登录状态  true:有用户登录信息 false 无用户登录信息
    /// 
    ///     注:默认类型为Info 可以配置其他日志 logType用于反射 规则一定要准确
    ///     例:  1.默认日志 LogWriter("test log");   正常的业务日志
    ///          2.异常日志 LogWriter("test log","Fatal");  try catch 里请使用这个日志级别
    ///     
    /// 
    public static void LogWriter(String msg, String logType = "Info", bool loginState = true)
    {
        try
        {
            String logMethod = "";  //调用者类名和方法名
            if (logType == "Fatal")
            {
                StackTrace trace = new StackTrace();
                //获取是哪个类来调用的  
                String invokerType = trace.GetFrame(1).GetMethod().DeclaringType.Name;
                //获取是类中的那个方法调用的  
                String invokerMethod = trace.GetFrame(1).GetMethod().Name;
                logMethod = invokerType + "." + invokerMethod + " | ";
            }

            String IP = HttpContext.Current.Request.UserHostAddress;   //获取IP
            //反射执行日志方法
            Type type = typeof(Logger);
            MethodInfo method = type.GetMethod(logType, new Type[] { typeof(String) });
            if (loginState == true)
            {
                //如果是登陆状态 可以记录用户的登陆信息 比如用户名,Id等
                method.Invoke(logger, new object[] { logMethod + msg + " [ " + IP + " | " + LogState.NLogin + " ]" });
            }
            else
            {
                method.Invoke(logger, new object[] { logMethod + msg + " [ " + IP + " | " + LogState.NLogin + " ]" });
            }
        }
        catch
        {
            //日志代码错误,直接记录日志
            Fatal(msg);
            Warn(msg);
        }
    }

    /// 
    /// 调试日志
    /// 
    /// 日志内容
    private static void Debug(String msg)
    {
        logger.Debug(msg);
    }

    /// 
    /// 信息日志
    /// 
    /// 日志内容
    /// 
    ///     适用大部分场景
    ///     1.记录日志文件
    /// 
    private static void Info(String msg)
    {
        logger.Info(msg);
    }

    /// 
    /// 错误日志
    /// 
    /// 日志内容
    /// 
    ///     适用异常,错误日志记录
    ///     1.记录日志文件
    /// 
    private static void Error(String msg)
    {
        logger.Error(msg);
    }

    /// 
    /// 严重致命错误日志
    /// 
    /// 日志内容
    /// 
    ///     1.记录日志文件
    ///     2.控制台输出
    /// 
    private static void Fatal(String msg)
    {
        logger.Fatal(msg);
    }

    /// 
    /// 警告日志
    /// 
    /// 日志内容
    /// 
    ///     1.记录日志文件
    ///     2.发送日志邮件
    /// 
    private static void Warn(String msg)
    {
        try
        {
            logger.Warn(msg);
        }
        catch { }
    }
}

如果是后台服务或者只简单记下日记 可以直接用

logger.Info(msg);
logger.Fatal(msg);

这样记录日志。
我这里写了个入口LogWriter用于统一调用,方便以后修改日志或者切换其他日志。


日志的配置文件为NLog.config,NLog的配置可以放在Web.config中,也可以放在单独的文件中,这里为了项目好维护,把配置放到一个单独的文件中,具体配置的内容为:


<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" throwExceptions="true">

  <targets xsi:type="AsyncWrapper">
    
    <target name="log_file" xsi:type="File" 
                    fileName="${basedir}/Logs/${shortdate}/${level:uppercase=false:padding=-5}.txt"
                    layout="${longdate} | ${message} ${onexception:${exception:format=tostring} ${newline} ${stacktrace} ${newline}" />
    
    <target name="debugger" xsi:type="Debugger" 
            layout="NLog: ${date:format=HH\:mm\:ss} | ${message}" />
    
    <target name="console" xsi:type="ColoredConsole" layout="${longdate} ${message} ${exception:format=tostring}">target>
    
     <target xsi:type="Mail" name="infoMail"
          smtpServer="smtp.163.com"  
          smtpPort="25"  
          smtpAuthentication="Basic"  
          smtpUserName="[email protected]"   
          smtpPassword="demo"  
          enableSsl="true"  
          addNewLines="true"  
          from="[email protected]"  
          to="[email protected]"  
          subject="Project Exception Mail"
          header="*********************"  
          body="${longdate} | ${message} "
          footer="*********************"/>
  targets>


  <rules>
    <logger name="*" level="Info" writeTo="log_file" />
    <logger name="*" levels="Error" writeTo="log_file" />
    <logger name="*" levels="Debug" writeTo="log_file" />
    
    
    <logger name="*" level="Fatal" writeTo="log_file" />
    
    <logger name="*" level="Warn" writeTo="log_file" />
  rules>
nlog>

好了,这样就可以使用NLog来记录日志了。

你可能感兴趣的:(.NET)