gpt4 book ai didi

c# - 在异常日志记录中跟踪用户 ID

转载 作者:塔克拉玛干 更新时间:2023-11-03 04:42:46 25 4
gpt4 key购买 nike

我有一个包含数百个并发用户的 Web 服务,我有一个静态日志记录类来记录抛出的错误。我需要在最初未被跟踪的记录器中跟踪 UserID。

这听起来很容易,因为我可以将 UserID 传递到 Logger 函数调用中,但因为这是一个遗留系统,我不能更改调用参数。我可以在程序第一次启动时或在记录器本身内部添加一些代码,但修改每个调用签名是不可能的。

如何在记录器中获取用户 ID 而无需在每次记录器调用时都传递给它?

这是我当前的功能以及我的问题是什么:

public static class Log
{
public static void Error(object message, Exception ex)
{
log.Error(message, ex);

IDictionary customData = new Dictionary<string, string>() {{"message", message.ToString()}};
customData.Add("UserID",???????);
DoLogging(ex, customData);
}
}

这是我无法使用的琐事解决方案:

public static class Log
{
public static void Error(object message, Exception ex, int userID)
{
log.Error(message, ex);

IDictionary customData = new Dictionary<string, string>() {{"message", message.ToString()}};
customData.Add("UserID", userID.ToString());
DoLogging(ex, customData);
}
}

一个可能的解决方案是在 Logger 类中保存某种类型的静态变量,但请记住,这个类是静态的,并且可能有数百个并发实例,我如何知道哪个实例正在调用记录器?

public static class Log
{
private static concurrent DataStrucutre userIDs;
public static void Error(object message, Exception ex)
{
log.Error(message, ex);

IDictionary customData = new Dictionary<string, string>() {{"message", message.ToString()}};
customData.Add("UserID",userIDs[????]);
DoLogging(ex, customData);
}
}

最佳答案

答案是你不能。

但是可以使参数可选。这样您修改的代码将具有 user_id 并且其他代码不会中断。

How can you use optional parameters in C#? 的答案讨论如何在 4.0 版或早期版本中(通过重载)执行此操作。

关于c# - 在异常日志记录中跟踪用户 ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35094667/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com