gpt4 book ai didi

stackexchange.redis - 如何将 TextWriter 用作 Serilog 的源?

转载 作者:行者123 更新时间:2023-12-03 17:25:57 24 4
gpt4 key购买 nike

StackExchange.Redis 将日志消息写入 TextWriter。它不使用 ILogger 接口(interface)进行日志记录。

我想将写入 TextWriter 的消息转换为 Serilog 调试级别的消息。

想法?

最佳答案

类似于以下内容(仅经过烟雾测试,但似乎有效):

public class TextWriterLogger : TextWriter
{
private ILogger logger;
private StringBuilder builder = new StringBuilder();
private bool terminatorStarted = false;

public TextWriterLogger(ILoggerFactory log)
{
logger = log.CreateLogger("RedisTrace");
}

public override void Write(string value)
{
logger.LogDebug(value);
}

public override void Write(char value)
{
builder.Append(value);
if (value == NewLine[0])
if (NewLine.Length == 1)
Flush2Log();
else
terminatorStarted = true;
else if (terminatorStarted)
if (terminatorStarted = NewLine[1] == value)
Flush2Log();
}

private void Flush2Log()
{
if (builder.Length > NewLine.Length)
logger.LogDebug(builder.ToString());
builder.Clear();
terminatorStarted = false;
}


public override Encoding Encoding
{
get { return Encoding.Default; }
}
}

关于stackexchange.redis - 如何将 TextWriter 用作 Serilog 的源?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53717433/

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