log4net 系统日志

大家好,这段时间公司叫我用log4net 给系统做个日志,初次接触的我一头雾水,后来在网上找了些资料,
发现这真是个很强大的东西,简单、实用,下面是我整合的资料,我已经调试过了,是正确的,希望和大家分享,共同学习:
1. log4net简介

log4net是.Net下一个非常优秀的开源日志记录组件。log4net记录日志的功能非常强大。它可以将日志分不同的等级,以不同的格式,输出到不同的媒介。
Java平台下,它还有一个姐妹组件——log4j。

log4net的下载地址:http://logging.apache.org/log4net/download.html

2. log4net的组成

log4net主要由五部分组成,分别为Appenders、Filters、Layouts、Loggers和Object Renders。

 

web.config 配置如下:

      <!--注册lognet-->
      <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
    </configSections>
  <!--站点日志配置部分-->
  <log4net>
    <root>
      <priority value="ALL"/>
      <appender-ref ref="TraceAppender"/>
      <appender-ref ref="ConsoleAppender"/>
      <appender-ref ref="RollingFileAppender"/>
    </root>
    <appender name="TraceAppender" type="log4net.Appender.TraceAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%newline%date [%thread] %-5level %logger [%property{NDC}] - %message%newline%newline"/>
      </layout>
    </appender>
    <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%newline%date [%thread] %-5level %logger [%property{NDC}] - %message%newline%newline"/>
      </layout>
    </appender>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="Log//SysLog"/>
      <!--日志文件夹及文件名开头-->
      <appendToFile value="true"/>
      <!--是否追加到文件-->
      <RollingStyle value="Date"/>
      <!--日期的格式-->
      <DatePattern value="yyyy-MM-dd&quot;.log&quot;"/>
      <!--文件名后面加上.log后缀,必须使用转义字符-->
      <maximumFileSize value="1MB" />
      <!--最大文件大小-->
      <StaticLogFileName value="false"/>
      <!--日志文件名是否为静态-->
      <layout type="log4net.Layout.PatternLayout,log4net">
        <param name="ConversionPattern" value="%newline%date [%thread] %-5level %logger [%property{NDC}] - %message%newline%newline"/>
        <param name="Header" value=" --------------------------网站运行过程中产生的错误--------------------------&#13;&#10;"/>
        <param name="Footer" value=" -------------------------------------测试:GZQ-------------------------------------&#13;&#10;"/>
      </layout>
    </appender>
  </log4net>

新建一个全局应用程序集( Global.asax )代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.SessionState;

namespace text
{
    public class Global : System.Web.HttpApplication
    {

        protected void Application_Start(object sender, EventArgs e)
        {
            //在HttpApplication 类的第一个实例被创建时,该事件被触发。它允许你创建可以由所有HttpApplication 实例访问的对象
           
            //读取配置信息
        log4net.Config.DOMConfigurator.Configure();


        }

        protected void Session_Start(object sender, EventArgs e)
        {
            //在一个新用户访问应用程序 Web 站点时,该事件被触发

        }

        protected void Application_BeginRequest(object sender, EventArgs e)
        {
            //在接收到一个应用程序请求时触发。对于一个请求来说,它是第一个被触发的事件,请求一般是用户输入的一个页面请求(URL)。
             string str = HttpContext.Current.Request.Path.ToString();
            str = str.Substring(8, str.Length -8);
       //   //  var list = menuNHR.Find<Point.Data.Domain.Menu>(string.Format("pathURl='"+str+"' and IsView=1","OrderBy",true ));
          IList<Point .Data .Domain .Menu > a=list as IList<Point.Data.Domain.Menu>;
       //   if (HttpContext.Current.User.Identity.Name!=null)
       //   {
       //       Point.Data.Domain.Log logModel = new Point.Data.Domain.Log();
       //       //logModel.Content = string.Format(
       //       //    this.Lang("loginlog",
       //       //    "用户【{0}】于【{1}】操作此菜单页面", true, HttpContext.Current.User.Identity.Name, DateTime.Now));
       //         //获取IP地址
       //       logModel.IP = Point.Utility.StringHandler.GetIP();
       //       logModel.PageUrl = str;
       //       logModel.CreateDate = DateTime.Now;
       //       logModel.UserName = HttpContext.Current.User.Identity.Name;
       //       HeadSystem.InsertLog(logModel);
        }

        protected void Application_AuthenticateRequest(object sender, EventArgs e)
        {
            //在 ASP.NET 页面框架得到与当前请求相关的当前状态(Session 状态)时,该事件被触发
        }

        protected void Application_Error(object sender, EventArgs e)
        {
            //当应用程序中遇到一个未处理的异常时,该事件被触发
            Exception ex = Server.GetLastError();
            if (ex != null)
            {
                //写入错误日志
                AppLog.Write("[Exception]:", AppLog.LogMessageType.Error, ex);

                //如果是 HttpException 异常 不处理, 显示403 404 页面
                if (ex is HttpException)
                {
                    HttpException httpEx = ex as HttpException;
                    if (httpEx.GetHttpCode() == 403 || httpEx.GetHttpCode() == 404)
                        return;
                }

                //Response.Redirect("~/Error.aspx");
            }
        }

        protected void Session_End(object sender, EventArgs e)
        {
            //在一个用户的会话超时、结束或他们离开应用程序 Web 站点时,该事件被触发。
            AppLog.Write("Web站点关闭...", AppLog.LogMessageType.Info);

        }

        protected void Application_End(object sender, EventArgs e)
        {
            //在HttpApplication 类的最后一个实例被销毁时,该事件被触发。在一个应用程序的生命周期内它只被触发一次
        }
    }
}


新建一个AppLog.cs 类 代码如下:
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using log4net;
using log4net.Config;

/// <summary>
///AppLog 的摘要说明
/// </summary>
public class AppLog
{
    /// <summary>
    /// 日志处理
    /// </summary

    private AppLog() { }
    private const string LOG_REPOSITORY = "Default"; // this should likely be set in the web config.
    private static ILog m_log;

    /// <summary>
    /// 初始化日志系统
    /// 在系统运行开始初始化
    /// Global.asax Application_Start内
    /// </summary>
    public static void Init()
    {

       // log4net.Config.XmlConfigurator.Configure();

    }

    /// <summary>
    /// 写入日志
    /// </summary>
    /// <param name="message">日志信息</param>
    /// <param name="messageType">日志类型</param>
    public static void Write(string message, LogMessageType messageType)
    {
        DoLog(message, messageType, null, Type.GetType("System.Object"));
    }

    /// <summary>
    /// 写入日志
    /// </summary>
    /// <param name="message">日志信息</param>
    /// <param name="messageType">日志类型</param>
    /// <param name="type"></param>
    public static void Write(string message, LogMessageType messageType, Type type)
    {
        DoLog(message, messageType, null, type);
    }

    /// <summary>
    /// 写入日志
    /// </summary>
    /// <param name="message">日志信息</param>
    /// <param name="messageType">日志类型</param>
    /// <param name="ex">异常</param>
    public static void Write(string message, LogMessageType messageType, Exception ex)
    {
        DoLog(message, messageType, ex, Type.GetType("System.Object"));
    }

    /// <summary>
    /// 写入日志
    /// </summary>
    /// <param name="message">日志信息</param>
    /// <param name="messageType">日志类型</param>
    /// <param name="ex">异常</param>
    /// <param name="type"></param>
    public static void Write(string message, LogMessageType messageType, Exception ex,
                             Type type)
    {
        DoLog(message, messageType, ex, type);
    }

    /// <summary>
    /// 断言
    /// </summary>
    /// <param name="condition">条件</param>
    /// <param name="message">日志信息</param>
    public static void Assert(bool condition, string message)
    {
        Assert(condition, message, Type.GetType("System.Object"));
    }

    /// <summary>
    /// 断言
    /// </summary>
    /// <param name="condition">条件</param>
    /// <param name="message">日志信息</param>
    /// <param name="type">日志类型</param>
    public static void Assert(bool condition, string message, Type type)
    {
        if (condition == false)
            Write(message, LogMessageType.Info);
    }

    /// <summary>
    /// 保存日志
    /// </summary>
    /// <param name="message">日志信息</param>
    /// <param name="messageType">日志类型</param>
    /// <param name="ex">异常</param>
    /// <param name="type">日志类型</param>
    private static void DoLog(string message, LogMessageType messageType, Exception ex,
                              Type type)
    {
        m_log = LogManager.GetLogger(type);

        switch (messageType)
        {
            case LogMessageType.Debug:
                AppLog.m_log.Debug(message, ex);
                break;

            case LogMessageType.Info:
                AppLog.m_log.Info(message, ex);
                break;

            case LogMessageType.Warn:
                AppLog.m_log.Warn(message, ex);
                break;

            case LogMessageType.Error:
                AppLog.m_log.Error(message, ex);
                break;

            case LogMessageType.Fatal:
                AppLog.m_log.Fatal(message, ex);
                break;
        }
    }

    /// <summary>
    /// 日志类型
    /// </summary>
    public enum LogMessageType
    {
        /// <summary>
        /// 调试
        /// </summary>
        Debug,
        /// <summary>
        /// 信息
        /// </summary>
        Info,
        /// <summary>
        /// 警告
        /// </summary>
        Warn,
        /// <summary>
        /// 错误
        /// </summary>
        Error,
        /// <summary>
        /// 致命错误
        /// </summary>
        Fatal
    }
}

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值