• 继承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;
                }
            }
        }
    }
  • 相关阅读:
    日期插件,年月,年月日,时分,年月时分
    <context:annotation-config/>
    Autowired注解
    context:component-scan 注解的扫描
    Servlet 是什么 有哪些类
    spring RestTemplate 出现 NoHttpResponseException 和 ConnectionTimeoutException
    java 动态加载groovy 脚本
    java 如何实现文件变动的监听
    英文文档地址
    Resource ResourceLoader
  • 原文地址:https://www.cnblogs.com/ChineseMoonGod/p/5351346.html
Copyright © 2020-2023  润新知