log4net logfornet 配置和用法

较好的参考地址:

http://in3040.blog.163.com/blog/static/116702443201091354028744/

http://dev.tot.name/dotnet/html/2008121/20081201212538.htm

--------------------------------------------------

原文地址:http://blog.csdn.net/javc/archive/2009/03/25/4022677.aspx

web.config配置如下:
<?xml version="1.0" encoding="utf-8" ?>

<configuration>
<configSections>
  <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
</configSections>
<log4net>
  <!--错误日志配置-->
  <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
   <param name="File" value="Log\\LogError\\" />  
   <param name="AppendToFile" value="true" />
   <param name="MaxSizeRollBackups" value="100" />
   <param name="MaxFileSize" value="10240" />
   <param name="StaticLogFileName" value="false" />
   <param name="DatePattern" value="yyyyMMdd" />
   <param name="RollingStyle" value="Date" />
   <layout type="log4net.Layout.PatternLayout">
    <param name="ConversionPattern" value="%n异常时间:%d [%t] %n异常级别:%-5p %n异 常 类:%c [%x] %n%m %n " />
   </layout>
  </appender>

<!--信息日志配置-->
  <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
   <param name="File" value="Log\\LogInfo\\" />
   <param name="AppendToFile" value="true" />
   <param name="MaxFileSize" value="10240" />
   <param name="MaxSizeRollBackups" value="100" />
   <param name="StaticLogFileName" value="false" />
   <param name="DatePattern" value="yyyyMMdd" />
   <param name="RollingStyle" value="Date" />
   <layout type="log4net.Layout.PatternLayout">
    <param name="ConversionPattern" value="%n日志时间:%d [%t] %n日志级别:%-5p %n日 志 类:%c [%x] %n%m %n" />
   </layout>
  </appender>  
  <!--控制台-->
  <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
   <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%5level [%thread] (%file:%line) - %message%newline" />
   </layout>
  </appender>

<!--log4net.LogManager.GetLogger("logerror")用这个来选择这种类型-->
  <logger name="logerror">
   <level value="ERROR" />
   <appender-ref ref="ErrorAppender" />
  </logger>
  <logger name="loginfo">
   <level value="INFO" />
   <appender-ref ref="InfoAppender" />
  </logger>  
  <root>
   <level value="INFO" />
   <appender-ref ref="InfoAppender" />
   <appender-ref ref="ConsoleAppender" />
  </root>
</log4net>
</configuration>

LOG操作类
using System;  
using System.IO;

/**//// <summary>  
    /// LogHelper的摘要说明。  
    /// </summary>  
    public class LogHelper  
    {  
        private SystemLog()  
        {  
        }  
 
        public static readonly log4net.ILog loginfo = log4net.LogManager.GetLogger("loginfo");   //选择<logger name="loginfo">的配置
  
        public static readonly log4net.ILog logerror = log4net.LogManager.GetLogger("logerror");   //选择<logger name="logerror">的配置
  
        public static void SetConfig()  
        {  
           log4net.Config.XmlConfigurator.Configure();  
        }  
 
        public static void SetConfig(FileInfo configFile)  
        {  
           log4net.Config.XmlConfigurator.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);  
            }  
        }  
    }

Global.asax.cs文件配置如下:

protected void Application_Start(Object sender, EventArgs e)  
  {  
            SystemLog.SetConfig();  
  }  
  protected void Application_Error(Object sender, EventArgs e)  
  {  
   Exception objExp = HttpContext.Current.Server.GetLastError();  
   LogHelper.WriteLog("\r\n客户机IP:"+ Request.UserHostAddress +"\r\n错误地址:"+ Request.Url +"\r\n异常信息:"+ Server.GetLastError().Message,objExp);  
  } 
protected void Application_Start(Object sender, EventArgs e)
  {
            SystemLog.SetConfig();
  }
  protected void Application_Error(Object sender, EventArgs e)
  {
   Exception objExp = HttpContext.Current.Server.GetLastError();
   LogHelper.WriteLog("\r\n客户机IP:"+ Request.UserHostAddress +"\r\n错误地址:"+ Request.Url +"\r\n异常信息:"+ Server.GetLastError().Message,objExp);
  }

eg:
   try
   {}
   catch(Exception ex)
   {
       LogHelper.WriteLog("ErrorInfo"ex);
   }

以上本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/javc/archive/2009/03/25/4022677.aspx

1.调用步骤

1.config配置

2.初始化配置 log4net.Config.XmlConfigurator.Configure();

3.调用logger.Info("asdfasd");

2.细节详解

1.Log4net框架定义了一个叫做LogManager的类,用来管理所有的logger对象。它有一个GetLogger()静态方法,用我们提供的名字参数来检索已经存在的Logger对象。如果框架里不存在该Logger对象,它也会为我们创建一个Logger对象。代码如下所示:

log4net.ILog log = log4net.LogManager.GetLogger("logger-name");

通常来说,我们会以类(class)的类型(type)为参数来调用GetLogger(),以便跟踪我们正在进行日志记录的类。传递的类(class)的类型(type)可以用typeof(Classname)方法来获得,或者可以用如下的反射方法来获得:
log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

尽管符号长了一些,但是后者可以用于一些场合,比如获取调用方法的类(class)的类型(type)。
例: private void button1_Click(object sender, EventArgs e)
        {

logger.Info("sdfasd");
        }

System.Reflection.MethodBase.GetCurrentMethod().DeclaringType 就为button1_Click这个方法所在的类的类型

2.配置XmlConfigurator

使用代码初始化配置。
log4net.Config.XmlConfigurator.Configure(new FileInfo("test.log4net"));
使用 XmlConfigurator.ConfigureAndWatch() 方法除了初始化配置外,还会监测配置文件的变化,一旦发生修改,将自动刷新配置。
我们还可以使用 XmlConfiguratorAttribute 代替 XmlConfigurator.Config()/ConfigureAndWatch(),ConfiguratorAttribute 用于定义与 Assembly 相关联的配置文件名。
方式1: 关联到 test.log4net,并监测变化。
[assembly: log4net.Config.XmlConfigurator(ConfigFile="test.log4net", Watch=true)]
方式2: 关联到 test.exe.log4net (或 test.dll.log4net,文件名前缀为当前程序集名称),并监测变化。
[assembly: log4net.Config.XmlConfigurator(ConfigFileExtension="log4net", Watch=true)]

时间: 2024-10-12 16:52:41

log4net logfornet 配置和用法的相关文章

【初学菜鸟作--KVM虚拟机配置及用法】

KVM虚拟机配置及用法 1.主要存放位置: 安装kvm虚拟机默认存放位置  --/var/lib/libvirt/images kvm虚拟机配置文件存放位置  --/etc/libvirt/qemu/ 2.常用管理命令: 管理命令 virsh list --查看已打开虚拟机列表 virsh list --all --查看所有虚拟机列表 virsh version --查看版本号 virsh start yeyue1     --启动虚拟机 virsh create /etc/libvirt/qe

Log4Net 日志配置

前述 园子里有许多人对log4net这款开源的日志记录控件有很多介绍.在这里个人再做一次总结,希望对以后有所帮助,需要的时候可以直接使用,减 少查阅资料的时间.利用log4net可以方便地将日志信息记录到文件.控制台.Windows事件日志和数据库,并且我们还可以记载控制要记载的日志级 别,可以记载的日志类别包括:FATAL(致命错误).ERROR(一般错误).WARN(警告).INFO(一般信息).DEBUG(调试信息). log4net 有四种主要的组件,分别是Logger(记录器), Re

Log4Net详细配置

关于Log4Net配置主要分几步 第一步:下载log4net.dll(log4net官网:http://logging.apache.org/log4net/download_log4net.cgi) 第二步:在项目中添加对log4net.dll的引用 第三步:配置log4net <?xml version="1.0" encoding="utf-8" ?><log4net> <!--The config of System's def

Log4Net 日志配置[附带源码]

前述 园子里有许多人对log4net这款开源的日志记录控件有很多介绍.在这里个人再做一次总结,希望对以后有所帮助,需要的时候可以直接使用,减少查阅资料的时间.利用log4net可以方便地将日志信息记录到文件.控制台.Windows事件日志和数据库,并且我们还可以记载控制要记载的日志级别,可以记载的日志类别包括:FATAL(致命错误).ERROR(一般错误).WARN(警告).INFO(一般信息).DEBUG(调试信息).log4net 有四种主要的组件,分别是Logger(记录器), Repos

【Django】MEDIA的配置及用法

如果需要在数据库中存储图片或视频类的数据,我们可以配置MEDIA. 下面的示例将以上传一张图片的形式来说明MEDIA的配置及用法. 第一步 settings.py # media配置 MEDIA_URL = 'media/' # 用于指定url路径 MEDIA_ROOT = os.path.join(BASE_DIR, "媒体库") # 用于指定上传文件的存储路径 第二步 urls.py from django.conf.urls import url from django.cont

【Django】MEDIA的配置及用法 -- 2019-08-08 18:01:56

原文: http://106.13.73.98/__/73/ 如果需要在数据库中存储图片或视频类的数据,我们可以配置MEDIA. 下面的示例将以上传一张图片的形式来说明MEDIA的配置及用法. 第一步 settings.py # media配置 MEDIA_URL = 'media/' # 用于指定url路径 MEDIA_ROOT = os.path.join(BASE_DIR, "媒体库") # 用于指定上传文件的存储路径 第二步 urls.py from django.conf.u

log4net的基本配置及用法

[1].[代码] [C#]代码 跳至 [1] [2] ? 1 2 using System.Reflection;  //使用反射 static private ILog log = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); [2].[代码] 配置 跳至 [1] [2] ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 2

sshpass 配置与用法介绍

sshpass 配置安装 一.sshpass介绍 ssh登陆不能在命令行中指定密码,需要用户交互输入密码,sshpass 的出现,解决了这一问题.它允许你用 -p 参数指定明文密码,然后直接登录远程服务器, 它支持密码从命令行.文件.环境变量中读取.所以,通过sshpass实现以非交互的形式为ssh提供密码. 二.安装配置 1.下载:目前1.0.5是最新版本,下载地址: wget http://sourceforge.net/projects/sshpass/files/sshpass/1.05

ssh 配置与用法

1. 背景 本地操作直接shell登陆处理,那远程操作就需要ssh,ssh提供加密验证和传输,提高通信的安全程度. 2. 配置 2.1 客户端配置 生成客户端密钥: $ ssh-keygen -t rsa$ > passphrase: <passwd> # used when decrypt privatekey on connecting to server$ ssh-copy-id -i ~/.ssh/id_dsa.pub [email protected] 在~/.ssh下生成私钥