VS2012 C#使用/配置Log4Net

2021-04-08 12:27

阅读:672

标签:title   image   vs2012   app   object   探讨   back   evel   lin   

最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来。

十年河东十年河西,莫欺少年穷

学无止境,精益求精  

本节探讨如何在VS2012中使用Log4Net

1、首先在项目中添加Nuget程序包...

技术分享图片

 2、然后在NuGet窗体中搜索Log4Net,然后点击安装

技术分享图片

3、在项目中添加一个Config文件,并命名为:Log4Net.config

技术分享图片

截图中配置的XML代码如下:

技术分享图片














技术分享图片

最后在项目的 AssemblyInfo.cs 文件中注册Config文件,如下:

技术分享图片

//为项目注册Log4Net.config配置文件
[assembly: log4net.Config.DOMConfigurator(ConfigFile = "Log4Net.config", Watch = true)]

最后,添加日志类:

技术分享图片
 public class LogHelper
    {
        private LogHelper()
        {
        }

        public static readonly log4net.ILog loginfo = log4net.LogManager.GetLogger("loginfo");

        public static readonly log4net.ILog logerror = log4net.LogManager.GetLogger("logerror");

        public static void SetConfig()
        {
            log4net.Config.DOMConfigurator.Configure();
        }

        public static void SetConfig(FileInfo configFile)
        {
            log4net.Config.DOMConfigurator.Configure(configFile); 
        }

        public static void WriteLog(string info)
        {
            if(loginfo.IsInfoEnabled)
            {
                loginfo.Info(info);
            }
        }

        public static void WriteLog(string info,Exception se)
        {
            if(logerror.IsErrorEnabled)
            {
                logerror.Error(info,se);
            }
        }
    }
技术分享图片

好了,到了这里,准备工作也就完成了,下面我们就开始测试下吧

首先引用:using log4net;

然后:

技术分享图片
    public partial class index : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            LogHelper.WriteLog("陈卧龙是个大坏蛋");
        }
    }
技术分享图片

最后,我们在项目中显示所有文件,你会发现有个Log文件夹,如下:

技术分享图片

我们打开LogInfo文件夹下20161220.txt便会看到我们打印的信息

技术分享图片

当然,您的代码也可以这样写:

技术分享图片
        protected void Page_Load(object sender, EventArgs e)
        {
            try
            {
                //todo
            }
            catch(Exception ex)
            {
                LogHelper.WriteLog("被除数为零,呃呃呃,小学数学没学好!", ex);
            }
        }
技术分享图片

在todo过程中一旦发生异常就会执行Catch()语段,这时会在LogError文件夹中的文件中写入日志。

 好了,Log4Net还有一些用法,在此不作举例了!

技术分享图片
        protected void Page_Load(object sender, EventArgs e)
        {
            try
            {
                //todo
                LogHelper.loginfo.Warn("警告消息");
                LogHelper.logerror.Warn("错误警告信息");
            }
            catch(Exception ex)
            {
                LogHelper.WriteLog("被除数为零,呃呃呃,小学数学没学好!", ex);
            }
        }
技术分享图片

等等吧!

VS2012 C#使用/配置Log4Net

标签:title   image   vs2012   app   object   探讨   back   evel   lin   

原文地址:https://www.cnblogs.com/Alex80/p/9086634.html


评论


亲,登录后才可以留言!