2017-03-24 12 views
0

我想从配置文件中添加最小日志级别和滚动文件路径等SeriLog设置。该标准是他们难以像这样的代码:如何访问.NET启动类构造函数中的AppSettings核心

public Startup(IHostingEnvironment env) 
{ 
    var builder = new ConfigurationBuilder() 
     .SetBasePath(env.ContentRootPath) 
     .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true) 
     .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true) 
     .AddEnvironmentVariables(); 
    Configuration = builder.Build(); 

    Log.Logger = new LoggerConfiguration() 
     .MinimumLevel.Debug() 
     .WriteTo.RollingFile("C:/LogFiles/log-{Date}.txt") 
     .CreateLogger(); 
} 

基本上,我需要能够从appsettings.json访问启动构造函数值。事情是这样的:

Log.Logger = new LoggerConfiguration() 
    .MinimumLevel.Is((LogEventLevel)Enum.Parse(typeof(LogEventLevel), 
     Configuration.GetValue<string>("AppSettings.MinimumLoggingLevel"))) 
    .WriteTo.RollingFile(Configuration.GetValue<string>("AppSettings.RollingFilePath")) 

我发现Configuration.GetValue语法在另一个SO发布,但它总是返回null

+0

什么是您的appsettings.json样子? –

回答

1

如果AppSettings部分是这样的:

"AppSettings": { 
    "RollingFilePath": "..." 
}, 

然后更改.:

.WriteTo.RollingFile(Configuration.GetValue<string>("AppSettings:RollingFilePath")) 

或使用一个

.WriteTo.RollingFile(Configuration["AppSettings:RollingFilePath"]) 
+0

Doh。我实际上已经尝试过,但我相信我正在使用一段时间而不是冒号。谢谢! – im1dermike

0

我appsettings.json看起来是这样的:

{ 
    "Logging": { 
    "IncludeScopes": false, 
    "LogLevel": { 
     "Default": "Debug", 
     "System": "Information", 
     "Microsoft": "Information" 
     } 
    } 
} 

要访问的值,我可以只使用这样的事情:

var IncludeScopes = Configuration.GetValue<bool>("Logging:IncludeScopes", true); 
相关问题