第一步:

添加并应用Log4net.dll。然后在Web.config文件中添加下面的配置局

<configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>

第二步:

新建Log4Net.config的配置文件,并在其中添加下面的配置信息:

<?xml version="1.0" encoding="UTF-8"?>
<log4net debug="false">

<!--按日期分割日志文件 一天一个-->
  <appender name="LogFileAppenderByDate" type="log4net.Appender.RollingFileAppender" >

<!--是否续写-->
    <param name="AppendToFile" value="true" />
    <!--最小锁定模型以允许多个进程可以写入同一个文件-->
    <param name="LockingModel" value="log4net.Appender.FileAppender.MinimalLock" />
    <param name="StaticLogFileName" value="true" />
    <!--保存路径-->
    <param name="File" value="d:\Log\\" />
    <param name="DatePattern" value="yyyy-MM-dd.LOG" />
    <param name="StaticLogFileName" value="false" />
    <param name="RollingStyle" value="Date" />
    <layout type="log4net.Layout.PatternLayout">
      <param name="ConversionPattern" value="时间:%d %n级别:%level %n类名:%c%n文件:%F 第%L行%n日志内容:%m%n-----------------------------------------%n%n" />
    </layout>
  </appender>

<!--按日志容量分割日志文件 10KB一个-->
  <appender name="LogFileAppenderBySize" type="log4net.Appender.RollingFileAppender" >
    <!--是否续写-->
    <param name="AppendToFile" value="true" />
    <!--最小锁定模型以允许多个进程可以写入同一个文件-->
    <param name="LockingModel" value="log4net.Appender.FileAppender.MinimalLock" />

<param name="StaticLogFileName" value="true" />

<!--按照文件的大小进行变换日志文件-->
    <param name="RollingStyle" value="Size" />
    <param name="File" value="log.txt" />
    <!--单个文件最大数量 好像只有在 按Size分割时有效-->
    <param name="MaximumFileSize" value="200KB"/>
    <!--保留的log文件数量 超过此数量后 自动删除之前的   好像只有在 按Size分割时有效-->
    <param name="MaxSizeRollBackups" value="2" />

<param name="StaticLogFileName" value="false" />
    <layout type="log4net.Layout.PatternLayout">
      <param name="ConversionPattern" value="发生时间:%d %n事件级别:%level %n相关类名:%c%n程序文件:%F 第%L行%n日志内容:%m%n-----------------------------------------%n%n" />
    </layout>
  </appender>

<!--记录日志到数据库-->
  <appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
    <bufferSize value="1" />
    <!--缓冲大小-->
    <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
    <connectionString value="Data Source=.\SQLEXPRESS;Initial Catalog=CVDS;User ID=sa;Password=sasa" />
    <commandText value="INSERT INTO Log([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
    <parameter>
      <parameterName value="@log_date" />
      <dbType value="DateTime" />
      <layout type="log4net.Layout.RawTimeStampLayout" />
    </parameter>
    <parameter>
      <parameterName value="@thread" />
      <dbType value="String" />
      <size value="255" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%thread" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@log_level" />
      <dbType value="String" />
      <size value="50" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%level" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@logger" />
      <dbType value="String" />
      <size value="255" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%logger" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@message" />
      <dbType value="String" />
      <size value="4000" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%message" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@exception" />
      <dbType value="String" />
      <size value="2000" />
      <layout type="log4net.Layout.ExceptionLayout" />
    </parameter>
  </appender>

<root>
    <level value="INFO" />
    <!--启用按日期分割-->
    <appender-ref ref="LogFileAppenderByDate" />
    <!--启用按容量分割-->
    <!--<appender-ref ref="LogFileAppenderBySize" />-->
    <!--启用保存到数据库-->
    <!--<appender-ref ref="AdoNetAppender" />-->
  </root>

</log4net>

第三步:

在Global.asax文件中的Application_Start事件中添加如下代码:

protected void Application_Start(object sender, EventArgs e)
  {
       // Code that runs on application startup
      log4net.Config.XmlConfigurator.ConfigureAndWatch(new FileInfo(Server.MapPath("Log4Net.config")));  
  }

第四步:调用LOG4net 写日志

protected void Button2_Click(object sender, EventArgs e)
        {
                     ILog logs = LogManager.GetLogger(typeof(TEST));

logs.Fatal("Excption:这里就是要提示的LOG信息");
        }

也可以通过写一个LogHelper.cs类进行封装:

using System;
using System.Collections.Generic;
using System.Web;
using log4net;

namespace SBIT.Web.Class
{
    /// <summary>
    /// 日志辅助类
    /// </summary>
    public class LogHelper
    {
        private static ILog log;
        private static LogHelper logHelper = null;
        /// <summary>
        /// 初始化
        /// </summary>
        /// <returns></returns>
        public static ILog GetInstance()
        {
            logHelper = new LogHelper(null);

return log;
        }
        /// <summary>
        /// 初始化
        /// </summary>
        /// <param name="configPath"></param>
        /// <returns></returns>
        public static ILog GetInstance(string configPath)
        {
            logHelper = new LogHelper(configPath);

return log;
        }
        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="configPath"></param>
        private LogHelper(string configPath)
        {
            if (!string.IsNullOrEmpty(configPath))
            {
                log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
                log4net.Config.XmlConfigurator.Configure(new System.IO.FileInfo(configPath));
            }
            else
            {
                log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
            }
        }

}
}

通过封装类写日志的方法如下:

private static readonly ILog logs = LogHelper.GetInstance(); //LogManager.GetLogger(typeof(TEST));
        protected void Button2_Click(object sender, EventArgs e)
        {
                logs.Fatal("Excption:这里就是要提示的LOG信息");
        }

log4net部分配置说明相关推荐

  1. log4net配置说明及使用方法

    下载地址 log4net.dll 1.配置 <configSections>     <section name="log4net" type="log ...

  2. C# 日志管理框架:Common.Logging和log4net

    01 - DLL引用 ‍common logging是一个通用日志接口框架,log4net是一个强大的具体实现框架. common logging可以把输出连接到其他非log类上, 如EntLib的日 ...

  3. Log4Net 全方位跟踪程序运行

    前端日子自己写了一个简单的日志跟踪程序,现在目前正在做的一个项目中使用以便于跟踪程序异常和运行状况,但是被否认了!可能是没有权威性,于是自己总结了一下Log4net日志跟踪系统,这里分享大家学习一下. ...

  4. log4net配置经验教训

    第一点:权限问题,一定要给要写入日志文件的目录宽松的权限. 本人就是因为权限问题浪费了很多时间.(因为iis user 的权限是相对低的,log4net又需要创建文件,所以权限一定要给足,后面可以用应 ...

  5. c# log组件 log4net使用介绍

    在软件开发和测试过程中,打印log信息是必不可少的调试方法.尤其在定位偶发性出现的问题的时候,用log的方式,就能体现出优势了. log4net是一个开源的log代码,只需要应用他的dll,并且在co ...

  6. Log4Net的控制台,WinForm,WebApplication使用

    一.Log4Net的控制台,WinForm,WebApplication使用 1.首先使用nuget 添加log4Net 到控制台项目中 log4j每个符号的具体含义:%d %5p %c{1}:%L ...

  7. linux kvm虚拟化命令,Linux系统下kvm虚拟化(三)日常管理常用命令和配置说明

    根据我们之前创建和一些操作可以知道,KVM虚拟机的管理主要是通过virsh命令对环境下kvm虚拟机进行管理,下边这里整理一些常用的配置说明以及如何进行日常管理维护. 1,查看KVM虚拟机配置文件 KV ...

  8. Angular应用中tsconfig.json文件配置说明及配置全局路径映射

    tsconfig.json文件配置说明 1. tsconfig.json文件中的选项配置 2. 配置全局路径映射 1. tsconfig.json文件中的选项配置 TypeScript编译器配置文件的 ...

  9. log4net 配置参数意思

    二)         Appenders Appenders决定日志输出的方式. Appenders必须实现log4net.Appenders.IAppender接口. Log4net 2 AnsiC ...

最新文章

  1. graphviz画图
  2. Python:条件判断
  3. pandas pivot 计算占比_数据分析Pandas 基础(二)
  4. GDCM:gdcm::ImageHelper的测试程序
  5. 任意给4条边求形成四边形面积最大值
  6. 超赞!12套你没见过的社交媒体 社交网站图标
  7. maven 版本号插件_Maven内部版本号插件–用法示例
  8. dtm文件生成等高线 lisp_南方cass如何用图面高程点生成等高线
  9. PyQt5学习--基本窗口控件--QLabel
  10. 关于 printf(%*.*s/n,m,n,ch) 的问题
  11. VirtualBox安装MACOSX 10.13虚拟机的增强功能
  12. 【引向】全栈开发工程师之路
  13. 企业管理软件系统的重要性
  14. 小白怎样使用EXCEL导入MATLAB画出图像
  15. C语言学习一些指针随笔记
  16. windows下kafka环境完整搭建,Python调用kafka构建完整实例分析与应用
  17. 黑龙江省力推互联网与畜牧产业深度融合 打造大数据中心
  18. 如何修改安卓软件的图标和名字
  19. [附源码]Java计算机毕业设计SSM大学生项目众筹系统
  20. 2017高考计算机试卷,2017年高考模拟试卷 信息技术卷.doc

热门文章

  1. 只需20小时,让0基础的你掌握小程序云开发!这个暑假,约否?
  2. luogu P3295 [SCOI2016]萌萌哒
  3. 【Alpha阶段】第一次Scrum Meeting
  4. 用带参数的方法给空数组放元素,寻找数组里面的值是否存在。
  5. mysql优化之连接优化
  6. VS2010 + QT 5 +open inventor 环境配置
  7. NYOJ 289 苹果(01背包)
  8. python批量操作Linux服务器脚本,ssh密码登录(执行命令、上传、下载)(一)...
  9. 图谱问答-句子向量模型部署项目总结(未完)
  10. 2018 蓝桥杯省赛 B 组模拟赛(一)H.封印之门 最短路