我想知道如何使用log4net(在我的示例中)在%logger模式中打印正确的类名。
在我的应用程序中,我使用的是实现日志记录界面的日志记录类(遵循SOLID)。其他类使用日志记录接口抽象来执行实际日志记录。我想切换到Log4Net,但我想保留日志记录抽象。自定义日志记录类方法将对象作为参数,并根据其状态创建日志。
因此,在下面的示例中,%logger模式将记录“MyLogger”,这是预期的,但我想记录调用类名称(在本例中为ObjectManipulator)。
using System.Reflection;
using log4net;
namespace LoggingTestur
{
class Program
{
class AnObject
{
public string State { get; set; }
}
interface IMyLogger
{
void LogObjectStateChenge(AnObject anObject);
}
class MyLogger : IMyLogger
{
private static readonly ILog Log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
public void LogObjectStateChenge(AnObject anObject)
{
Log.InfoFormat("AnObject's state is: {0}", anObject.State);
}
}
class ObjectManipulator
{
private readonly IMyLogger _logger;
public ObjectManipulator(IMyLogger logger)
{
_logger = logger;
}
public void Manipulate()
{
var anObject = new AnObject { State = "New" };
_logger.LogObjectStateChenge(anObject);
}
}
static void Main(string[] args)
{
var logger = new MyLogger();
var manipulator = new ObjectManipulator(logger);
manipulator.Manipulate();
}
}
}
答案 0 :(得分:0)
您可以通过几种方式获取班级名称:
将其作为参数传递,即LogObjectStateChange(AnObject anObject, Type type = null);
如果您的目标是4.5运行时,可以使用CallerFilePath属性获取文件名,并从中提取类名(假设每个类有一个文件和文件名与班级名称相同),即LogObjectStateChange(AnObject anObject, [CallerFilePath] string fileName = "")
使用反射从CallStack和StackFrame类中获取调用类。请注意,在Release版本中,编译器可能会内联方法或重新排列内容,从而导致堆栈跟踪中的信息不正确。