原文地址:http://www.cnblogs.com/zdh8675/p/3645556.html

这几天刚好在调整一个项目,把一些自己不是很清楚的东西先试验一下,这篇文章主要是对我在项目中需要使用Log4Net的一些记录。网上有很多相关的教程,但是各有各的说法,我结合我自己这个项目的需要,首先,项目是分多层的,假如每一层都需要加入日志记录,那该怎么办呢,下面是我的一些操作步骤,记录出来和大家分享一下,不足之处希望大家多拍板砖多多指教。

这个截图是我的当前项目的层次结构,首先在Common层先添加log4net.dll的引用(仅需这里添加引用即可),然后创建一个log4net.config(见红色数字2),我当前项目的1、4、5三处的log4net.config都是同一个,至于每层到底debug输出到的文件名是要叫做”DigitalGolf2Bug.txt“呢还是叫”ServiceApiDebug.txt“呢,可以分开在相应的4或者5里面去配,有更多的层也是同理,如果对名称无特别要求的话,那我默认debug是输出到文件”debug.txt“,而error是输出到”error.txt“,而info是输出到文件”info.txt“,之后打开Common层的AssemblyInfo文件,添加红色数字3的那句代码。最后,在红色数字5的log4net.config上点右键,选择“属性”--“复制到输出目录”--“始终复制”,这样就配置就全部搞定了,只需要在你想输出日志的地方调用LogHelper里面的方法即可。

log4net.config 配置文件:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<!-- 注册log4net -->
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
</configSections>
<log4net>
<!-- 定义日志记录器,可多个 -->
<logger name="logerror">
<level value="ERROR" />
<appender-ref ref="LogErrorAppender" />
</logger>
<logger name="logdebug">
<level value="DEBUG" />
<appender-ref ref="LogDebugAppender" />
</logger>
<logger name="loginfo">
<level value="INFO" />
<appender-ref ref="LogInfoAppender" />
</logger> <!-- 输出到错误信息文件 -->
<appender name="LogErrorAppender" type="log4net.Appender.FileAppender">
<param name="File" value="error.txt" />
<param name="AppendToFile" value="true" />
<param name="MaxSizeRollBackups" value="" />
<!-- 备份日志数目 -->
<param name="MaxFileSize" value="" />
<!-- 日志文件大小10M -->
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd HH:mm:ss" />
<param name="RollingStyle" value="Date" />
<!-- 创建新文件的方式,Date表示按日期创建,Size是按文件大小,etc -->
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%n异常时间:%d%n异常级别:%-5p%n异常内容:%m%n" />
</layout>
</appender> <!-- 输出到调试信息文件 -->
<appender name="LogDebugAppender" type="log4net.Appender.FileAppender">
<param name="File" value="debug.txt" />
<param name="AppendToFile" value="true" />
<param name="MaxSizeRollBackups" value="" />
<!-- 备份日志数目 -->
<param name="MaxFileSize" value="" />
<!-- 日志文件大小10M -->
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd HH:mm:ss" />
<param name="RollingStyle" value="Date" />
<!-- 创建新文件的方式,Date表示按日期创建,Size是按文件大小,etc -->
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%n调试时间:%d%n调试内容:%m%n" />
</layout>
</appender> <!-- 输出到一般信息文件 -->
<appender name="LogInfoAppender" type="log4net.Appender.FileAppender">
<param name="File" value="info.txt" />
<param name="AppendToFile" value="true" />
<param name="MaxSizeRollBackups" value="" />
<!-- 备份日志数目 -->
<param name="MaxFileSize" value="" />
<!-- 日志文件大小10M -->
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd HH:mm:ss" />
<param name="RollingStyle" value="Date" />
<!-- 创建新文件的方式,Date表示按日期创建,Size是按文件大小,etc -->
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%n调试时间:%d%n输出内容:%m%n" />
</layout>
</appender>
</log4net>
</configuration>

LogHelper.cs 类:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Web.UI.WebControls; namespace Common
{
public class LogHelper
{
private static readonly log4net.ILog log_err = log4net.LogManager.GetLogger("logerror");
private static readonly log4net.ILog log_debug = log4net.LogManager.GetLogger("logdebug");
private static readonly log4net.ILog log_info = log4net.LogManager.GetLogger("loginfo"); /// <summary>
/// 错误信息记录
/// </summary>
/// <param name="description">简单描述</param>
/// <param name="ex">错误信息</param>
public static void LogError(string description, Exception ex)
{
if (log_err.IsErrorEnabled) log_err.Error(description, ex);
} public static void LogError(object message)
{
if (log_err.IsErrorEnabled) log_err.Error(message);
} /// <summary>
/// 调试信息记录
/// </summary>
/// <param name="message">调试信息</param>
public static void LogDebug(object message)
{
if (log_debug.IsDebugEnabled) log_debug.Debug(message);
} public static void LogDebug(object message, Exception ex)
{
if (log_debug.IsDebugEnabled) log_debug.Debug(message, ex);
} /// <summary>
/// 一般信息记录
/// </summary>
/// <param name="message">一般信息</param>
public static void LogInfo(object message)
{
if (log_info.IsInfoEnabled) log_info.Info(message);
} public static void LogInfo(object message, Exception ex)
{
if (log_info.IsInfoEnabled) log_info.Info(message, ex);
}
}
}

Log4Net 在多层项目中的使用小记的更多相关文章

  1. (转载)Log4Net 在多层项目中的使用小记

    (原创)Log4Net 在多层项目中的使用小记 这几天刚好在调整一个项目,把一些自己不是很清楚的东西先试验一下,这篇文章主要是对我在项目中需要使用Log4Net的一些记录.网上有很多相关的教程,但是各 ...

  2. (原创)Log4Net 在多层项目中的使用小记

    这几天刚好在调整一个项目,把一些自己不是很清楚的东西先试验一下,这篇文章主要是对我在项目中需要使用Log4Net的一些记录.网上有很多相关的教程,但是各有各的说法,我结合我自己这个项目的需要,首先,项 ...

  3. 在 .Net 项目中生成Report小记

    背景 项目为WinForm + WCF 的应用,按照给定格式生成Report,显示在WinForm窗体上并可以导出为PDF和Excel文件. 分析 之前用过DevExpress For WinForm ...

  4. asp.net Web项目中使用Log4Net进行错误日志记录

      使用log4net可以很方便地为应用添加日志功能.应用Log4net,开发者可以很精确地控制日志信息的输出,减少了多余信息,提高了日志记录性能.同时,通过外部配置文件,用户可以不用重新编译程序就能 ...

  5. 在类库项目中使用log4net(RollingFileAppender)记录日志

    1.创建解决方案 2.创建类库项目 3.根据需要修改命名空间,修改(和/或)添加类到类库 4.引用log4net 5.类库项目根目录下创建leg4net配置文件,如D3CallTriggerPlugi ...

  6. log4net.dll配置以及在项目中应用 zt

    1 首先在项目中引用log4net.dll,然后项目中添加一个配置文件log4net.config <?xml version="1.0" encoding="ut ...

  7. 浅谈Log4net在项目中如何记录日志

    一    引入背景 在软件开发周期中,无论是开发中,或是测试中,或是上线后,选择合适的工具监控程序的运行状态至关重要,只有如此,才能更好地排查程序问题和检测程序性能问题等.本篇文章主要与大家分享,如何 ...

  8. VS2010中NET4项目中使用LOG4NET办法

    两年以前项目中是用的log4net.dll是net2.0环境下面的,最近在官网http://logging.apache.org/log4net/download_log4net.cgi找到了net4 ...

  9. C# 在项目中配置Log4net

    我们介绍一下在项目中配置log4net,是Apache基金会旗下的. 无论在什么环境中,配置log4net的逻辑都一样. 1)文件配置 首先在项目加载文件中,配置log4net加载项. 在Web项目中 ...

随机推荐

  1. ASP.NET MVC 3.0 Controller基础

    ASP.NET MVC 3.0 Controller基础   1.Controller类与方法 Controller(控制器)是ASP.NET MVC的核心,负责处理浏览器请求,并作出响应.Cotro ...

  2. 【Android】Android程序保护与破解浅析

    此文源自组内成员分享的PPT,其他成员的文档由于没有得到授权,暂不公开. 本文命令如果没有特殊注明,均为windows 7环境. 本文只涉及大概的知识点,不涉及具体的细节,需要注意. 反编译 apkt ...

  3. ehcache基本原理

    ehcache是现在最流行的纯Java开源缓存框架,配置简单.结构清晰.功能强大,最初知道它,是从Hibernate的缓存开始的.网上中文的EhCache材料以简单介绍和配置方法居多,如果你有这方面的 ...

  4. cocos2d-x ios8 输入框显示bug

    https://github.com/cocos2d/cocos2d-x/pull/8149

  5. 关于 Unity 中 ModelImporter.optimizeGameObjects

         ModelImporter.optimizeGameObjects 能够优化骨骼动画,将无用的骨骼合并,效率测试官方给出的数据差距比较大( Unity CJ 干货分享:全新的Unity移动游 ...

  6. 【原创】Java移位运算

    学习移位运算,首先得知道参与移位运算的类型的位数,那先来复习下Java基础类型的占位数吧. Java基础类型 Java基础类型总结一览表 类型 二进制位数 最大值 最小值 初始化值 表示形式 带符号 ...

  7. HDU4349--Xiao Ming's Hope(数论)

    输入一个n(1<=n<=108),求C(n,0),C(n,1),C(n,2)...C(n,n)有多少个奇数. Lacus定理 http://blog.csdn.net/acm_cxlove ...

  8. Linux下OpenSSL 安装

    安装环境:  操作系统:CentOs6.3 OpenSSL Version:openssl-1.0.0e.tar.gz 目前版本最新的SSL地址为http://www.openssl.org/sour ...

  9. Redis: OOM command not allowed when used memory > ‘maxmemory

    Redis: OOM command not allowed when used memory > ‘maxmemory’ 解决方式: $ vim /etc/redis/6903.conf ma ...

  10. vc关于文件拷贝

    单个文件的拷贝 system  针对单个文件 CopyFile  针对单个文件 /** @file_extension egg: .txt .png **/ void CopyFileToDir(CS ...