zoukankan      html  css  js  c++  java
  • 继承log4.net的类

    using System;
    using System.Diagnostics;
    
    [assembly: log4net.Config.XmlConfigurator(Watch = true)]
    namespace Hbl.Core
    {
        public static class Log
        {
    
            /// <summary>
            /// 一般错误
            /// </summary>
            /// <param name="message">消息</param>
            public static void Error(object message)
            {
                log4net.ILog log = log4net.LogManager.GetLogger(GetCurrentMethodFullName());
                log.Error(message);
               
            }
    
            /// <summary>
            /// 一般错误
            /// </summary>
            /// <param name="message">消息</param>
            /// <param name="exception">异常</param>
            public static void Error(object message, Exception exception)
            {
                log4net.ILog log = log4net.LogManager.GetLogger(GetCurrentMethodFullName());
                log.Error(message, exception);
            }
    
    
            /// <summary>
            /// 信息
            /// </summary>
            /// <param name="message">消息</param>
            public static void Info(object message)
            {
                log4net.ILog log = log4net.LogManager.GetLogger(GetCurrentMethodFullName());
                log.Info(message);
            }
    
            /// <summary>
            /// 信息
            /// </summary>
            /// <param name="message">消息</param>
            /// <param name="exception">异常</param>
            public static void Info(object message, Exception ex)
            {
                log4net.ILog log = log4net.LogManager.GetLogger(GetCurrentMethodFullName());
                log.Info(message, ex);
            }
    
            /// <summary>
            /// 警告
            /// </summary>
            /// <param name="message">消息</param>
            public static void Warn(object message)
            {
                log4net.ILog log = log4net.LogManager.GetLogger(GetCurrentMethodFullName());
                log.Warn(message);
            }
    
            /// <summary>
            /// 警告
            /// </summary>
            /// <param name="message">消息</param>
            /// <param name="exception">异常</param>
            public static void Warn(object message, Exception ex)
            {
                log4net.ILog log = log4net.LogManager.GetLogger(GetCurrentMethodFullName());
                log.Warn(message, ex);
            }
    
            /// <summary>
            /// 调试
            /// </summary>
            /// <param name="message">消息</param>
            public static void Debug(object message)
            {
                log4net.ILog log = log4net.LogManager.GetLogger(GetCurrentMethodFullName());
                log.Debug(message);
            }
    
            /// <summary>
            /// 调试
            /// </summary>
            /// <param name="message">消息</param>
            /// <param name="exception">异常</param>
            public static void Debug(object message, Exception ex)
            {
                log4net.ILog log = log4net.LogManager.GetLogger(GetCurrentMethodFullName());
                log.Debug(message, ex);
            }
    
            static string GetCurrentMethodFullName()
            {
                try
                {
                    int depth = 2;
                    StackTrace st = new StackTrace();
                    int maxFrames = st.GetFrames().Length;
                    StackFrame sf;
                    string methodName, className;
                    Type classType;
                    do
                    {
                        sf = st.GetFrame(depth++);
                        classType = sf.GetMethod().DeclaringType;
                        className = classType.ToString();
                    } while (className.EndsWith("Exception") && depth < maxFrames);
                    methodName = sf.GetMethod().Name;
                    return className + "." + methodName;
                }
                catch
                {
                    return null;
                }
            }
        }
    }
  • 相关阅读:
    H5软键盘搜索
    ios顺畅滑动
    自定义滚动条样式
    mockjs模拟数据(本地版)
    移动端防止窗体滚动
    css超出部分省略号
    H5自带的type=date或者month等日期控件移动端显示placeholder
    判断是否在微信内打开
    滚动加载数据
    activemq 5.6 连接池的内存泄露问题
  • 原文地址:https://www.cnblogs.com/ChineseMoonGod/p/5351346.html
Copyright © 2011-2022 走看看