zoukankan      html  css  js  c++  java
  • Log4Net的WebApplication使用

    一、Log4Net的WebApplication使用

     1、首先使用nuget 添加log4Net 到WebApplication项目中

    log4j每个符号的具体含义:%d %5p %c{1}:%L - %m%n

    log4j.properties

    # %m 输出代码中指定的消息
    # %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
    # %r 输出自应用启动到输出该log信息耗费的毫秒
    # %c 输出所属的类目,通常就是所在类的全名
    # %t 输出产生该日志事件的线程名
    # %n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
    # %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
    # %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。
    log4j.appender.stdout.layout.ConversionPattern=%d [%t] %-5p %c - %m%n

    #日志文件 每日
    log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
    log4j.appender.A1.File=F:/mylog.txt
    log4j.appender.A1.layout=org.apache.log4j.PatternLayout
    #%时间 [%线程] %log级别 %完整类名 - %消息 %换行
    log4j.appender.A1.layout.ConversionPattern=%d [%t] %-5p %c - %m%n

    2、在WebApplication项目的App.config中添加下面内容(只要是设置日志的添加类型,路径等)

    <log4net>
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
    <param name="File" value="LogLog.txt" />
    <param name="AppendToFile" value="true" />
    <param name="MaxSizeRollBackups" value="100" />
    <param name="MaximumFileSize" value="2MB" />
    <param name="RollingStyle" value="Size" />
    <param name="StaticLogFileName" value="true" />
    <layout type="log4net.Layout.PatternLayout">
    <param name="ConversionPattern" value="%-15p %d [%c] %m%n" />
    </layout>
    </appender>

    <appender name="consoleApp" type="log4net.Appender.ConsoleAppender,log4net">//控制台输出

    <layout type="log4net.Layout.PatternLayout,log4net">

    <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />

    </layout>

    </appender>

    <root>
    <level value="all" />
    <appender-ref ref="RollingLogFileAppender" />
    </root>
    </log4net>

    3、在WebApplication项目的Properties中的AssemblyInfo.cs中添加下面内容

    [assembly: log4net.Config.DOMConfigurator(Watch = true)](不建议使用,已经过时了)
    [assembly: log4net.Config.XmlConfigurator(ConfigFileExtension = "config", Watch = true)]

    4、在MVC 项目则是在  Global.asax.cs文件中添加下面内容

    public class MvcApplication : System.Web.HttpApplication
    {
    protected void Application_Start()
    {
    AreaRegistration.RegisterAllAreas();
    FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
    RouteConfig.RegisterRoutes(RouteTable.Routes);
    BundleConfig.RegisterBundles(BundleTable.Bundles);
    log4net.Config.XmlConfigurator.Config();//处理log4日志
    }
    }

    4、在WinForm项目启动项项目中使用

    static class Program
    {
    public static log4net.ILog LOG = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
    /// <summary>
    /// 应用程序的主入口点。
    /// </summary>
    [STAThread]
    static void Main()
    {
    //捕获未处理异常
    Application.SetUnhandledExceptionMode(UnhandledExceptionMode.CatchException);
    Application.ThreadException += new System.Threading.ThreadExceptionEventHandler(Application_ThreadException);
    AppDomain.CurrentDomain.UnhandledException += new UnhandledExceptionEventHandler(CurrentDomain_UnhandledException);

    Application.EnableVisualStyles();
    Application.SetCompatibleTextRenderingDefault(false);
    Application.Run(new Form1());
    }

    static void Application_ThreadException(object sender, System.Threading.ThreadExceptionEventArgs e)
    {
    LOG.Error(e.Exception);
    //throw new Exception("线程未知异常", e.Exception);
    MessageBox.Show(e.Exception.Message, "线程异常", MessageBoxButtons.OK, MessageBoxIcon.Error);
    Application.Exit();
    }

    static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
    {
    Exception ex = e.ExceptionObject as Exception;
    LOG.Error(ex);
    MessageBox.Show(ex.Message, "应用程序异常", MessageBoxButtons.OK, MessageBoxIcon.Error);
    Application.Exit();
    }
    }

     1、首先使用nuget 添加log4Net 到WinForm项目中

    log4j每个符号的具体含义:%d %5p %c{1}:%L - %m%n

    log4j.properties

    # %m 输出代码中指定的消息
    # %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
    # %r 输出自应用启动到输出该log信息耗费的毫秒
    # %c 输出所属的类目,通常就是所在类的全名
    # %t 输出产生该日志事件的线程名
    # %n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
    # %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
    # %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。
    log4j.appender.stdout.layout.ConversionPattern=%d [%t] %-5p %c - %m%n

    #日志文件 每日
    log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
    log4j.appender.A1.File=F:/mylog.txt
    log4j.appender.A1.layout=org.apache.log4j.PatternLayout
    #%时间 [%线程] %log级别 %完整类名 - %消息 %换行
    log4j.appender.A1.layout.ConversionPattern=%d [%t] %-5p %c - %m%n

    2、在WinForm项目的App.config中添加下面内容(只要是设置日志的添加类型,路径等)

    <log4net>
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
    <param name="File" value="LogLog.txt" />
    <param name="AppendToFile" value="true" />
    <param name="MaxSizeRollBackups" value="100" />
    <param name="MaximumFileSize" value="2MB" />
    <param name="RollingStyle" value="Size" />
    <param name="StaticLogFileName" value="true" />
    <layout type="log4net.Layout.PatternLayout">
    <param name="ConversionPattern" value="%-15p %d [%c] %m%n" />
    </layout>
    </appender>
    <root>
    <level value="all" />
    <appender-ref ref="RollingLogFileAppender" />
    </root>
    </log4net>

    3、在WinForm项目的Properties中的AssemblyInfo.cs中添加下面内容

    [assembly: log4net.Config.DOMConfigurator(Watch = true)](不建议使用,已经过时了)
    [assembly: log4net.Config.XmlConfigurator(ConfigFileExtension = "config", Watch = true)]

    4、在WinForm项目启动项项目中使用

    static class Program
    {
    public static log4net.ILog LOG = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
    /// <summary>
    /// 应用程序的主入口点。
    /// </summary>

    class Program
    {
    static log4net.ILog Log = log4net.LogManager.GetLogger(typeof(Program));
    static void Main(string[] args)
    {
    Log.Info("111111111111111111111111");
    Log.Warn("111111111111111111111111");
    Log.Error("111111111111111111111111");
    }
    }

  • 相关阅读:
    Redis学习第二天
    Redis学习
    jQuery基础
    Hashtable 和 HashMap 的区别
    JSP页面乱码问题
    Day28 java8:Stream API
    转 链表中节点每k个一组反转
    day 27 lambda表达式(针对接口) & 函数式接口
    day20异常2
    day20 异常1
  • 原文地址:https://www.cnblogs.com/1175429393wljblog/p/8037600.html
Copyright © 2011-2022 走看看