使用 web.config 配置 Serilog 文件
Configuring Serilog File with web.config
我正在尝试为 .NET FW 4.7.1 项目配置 Serilog。这是我的 web.config:
问题:serilog:write-to:File.outputTemplate
不工作
<appSettings>
<add key="serilog:minimum-level" value="Debug" />
<add key="serilog:using:File" value="Serilog.Sinks.File" />
<!--<add key="serilog:write-to:File.path" value="C:\Logs" />--> (This will be dynamically generate, Per User)
<add key="serilog:write-to:File.outputTemplate" value="{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level:u4}] | ({**AppName**}) | {Message:lj}{NewLine}{Exception}" />
<add key="serilog:write-to:File.shared" value="true" />
<add key="serilog:write-to:File.rollingInterval" value="Day"/>
<add key="serilog:enrich:with-property:AppName" value="MyApp" />
</appSettings>
在代码中,
var userlogPath = Path.Combine("C:\Logs", $"User_{UserId}_.log"); // Logged in **UserId** will be passed.
var logger = Log.Logger = new LoggerConfiguration()
.ReadFrom.AppSettings()
.WriteTo.File(userlogPath)
.CreateLogger();
logger.Information("Test Log");
// 它没有考虑来自 Web.Config 的 outputTemplate。也不记录 AppName
。
无法在代码中混合使用 XML 配置和 WriteTo.File()
。
要么 File.path
需要在 XML 中指定(如您所示,已注释掉),要么 File.outputTemplate
等其他设置需要提供给 WriteTo.File()
.
我正在尝试为 .NET FW 4.7.1 项目配置 Serilog。这是我的 web.config:
问题:serilog:write-to:File.outputTemplate
不工作
<appSettings>
<add key="serilog:minimum-level" value="Debug" />
<add key="serilog:using:File" value="Serilog.Sinks.File" />
<!--<add key="serilog:write-to:File.path" value="C:\Logs" />--> (This will be dynamically generate, Per User)
<add key="serilog:write-to:File.outputTemplate" value="{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level:u4}] | ({**AppName**}) | {Message:lj}{NewLine}{Exception}" />
<add key="serilog:write-to:File.shared" value="true" />
<add key="serilog:write-to:File.rollingInterval" value="Day"/>
<add key="serilog:enrich:with-property:AppName" value="MyApp" />
</appSettings>
在代码中,
var userlogPath = Path.Combine("C:\Logs", $"User_{UserId}_.log"); // Logged in **UserId** will be passed.
var logger = Log.Logger = new LoggerConfiguration()
.ReadFrom.AppSettings()
.WriteTo.File(userlogPath)
.CreateLogger();
logger.Information("Test Log");
// 它没有考虑来自 Web.Config 的 outputTemplate。也不记录 AppName
。
无法在代码中混合使用 XML 配置和 WriteTo.File()
。
要么 File.path
需要在 XML 中指定(如您所示,已注释掉),要么 File.outputTemplate
等其他设置需要提供给 WriteTo.File()
.