• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

ASP.NET Core中修改配置文件后自动加载新配置的方法详解

asp 搞代码 4年前 (2022-01-03) 63次浏览 已收录 0个评论

这篇文章主要给大家介绍了关于ASP.NET Core中修改配置文件后自动加载新配置的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用ASP.NET Core具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

前言

在 ASP.NET Core 默认的应用程序模板中, 配置文件的处理如下面的代码所示:

 config.AddJsonFile( path: "appsettings.json", optional: true, reloadOnChange: true ); config.AddJsonFile( path: $"appsettings.{env.EnvironmentName}.json", optional: true, reloadOnChange: true );

appsettings.json 和 appsettings.{env.EnvironmentName}.json 两个配置文件都是可选的, 并且支持当文件被修改时能够重新加载。

可以在 ASP.NET Core 应用中利用这个特性, 实现修改配置文件之后, 不需要重启应用, 自动加载修改过的配置文件, 从而减少系统停机的时间。 实现的步骤如下:

使用配置 API 进行注入

假设要在程序中注入这样一个配置类型:

 public class WeatherOption { public string City { get; set; } public int RefreshInterval { get; set; } }

在 appsettings.json 中添加的配置如下:

 { "weather": { "city": "GuangZhou", "refreshInterval": 120 } }

在 Startup.cs 的 ConfigureServices 方法中使用配置 API 进行注入, 代码如下:

 public void ConfigureServices(IServiceCollection services) { services.Configure(Configuration.GetSection("weather")); services.AddControllers(); }

这个步骤很关键, 通过这个配置 API 可以把注入内容和配置所在的节点关联起来。 如果有兴趣了解底层实现的话, 可以继续查看这个 OptionsConfigurationServiceCollectionExtensions.cs 。

通过这种方式注册的内容, 都是支持当配置文件被修改时, 自动重新加载的。

在控制器 (Controller) 中加载修改过后的配置

控制器 (Controller) 在 ASP.NET Core 应用的依赖注入容器中注册的生命周期是 Scoped , 即每次请求都会创建新的控制器实例。 这样只需要在控制器的构造函数中注入 IOptionsSnapshot 参数即可, 代码如下:

 [ApiController] [Route("[controller]")] public class WeatherForecastController : ControllerBase { private WeatherOption option; public WeatherForecastController( IOptionsSnapshot options ) { this.option = options.Value; } // GET /weatherforcase/options [HttpGet("options")] public ActionResult GetOption() { return options; } }

当然, 如果不希望在控制器中使用这个 IOptionsSnapshot 接口类型(会带来一些对现有代码重构和修改, 还是有一定的风险的), 可以在 ConfigureServices 中添加对 WeatherOption 的注入, 代码如下:

 public void ConfigureServices(IServiceCollection services) { services.Configure(Configuration.GetSection("weather")); // 添加对 WeatherOption 的注入, 生命周期为 Scoped , 这样每次请求都可以获取新的配置值。 services.AddScoped(serviceProvider => { var snapshot = serviceProvider.GetService<IOptionsSnapshot>(); return snapshot.Value; }); services.AddControllers(); }

这样在控制器中就不需要注入 IOptionsSnapshot 类型了, 最终控制器的代码如下:

 [ApiController] [Route("[controller]")] public class WeatherForecastController : ControllerBase { private WeatherOption option; public WeatherForecastController( WeatherOption option ) { this.option = option; } // GET /weatherforcase/options [HttpGet("options")] public ActionResult GetOption() { return options; } }

这样控制器就无需修改任何代码即可加载修改过后的新配置。

在中间件 (Middleware) 中加载修改过后的配置

中间件 (Middleware) 在 ASP.NET Core 应用的依赖注入容器中注册的生命周期是 Singleton , 即单例的, 只有在当应用启动时, 根据中间件创建处理连时创建一次全局实例, 所以只能通过注入 IOptionsMonitor 来监听配置文件的修改情况, 示例代码如下:

 public class TestMiddleware { private RequestDelegate next; private WeatherOption option; public TestMiddleware( RequestDelegate next, IOptionsMonitor monitor ) { this.next = next; option = monitor.CurrentValue; // moni config change monitor.OnChange(newValue => { option = newValue; }); } public async Task Invoke(HttpContext context) { await context.Response.WriteAsync(JsonSerializer.Serialize(option)); } }

当然, 在中间件的 Task Invoke(HttpContext context) 方法中, 直接获取 IOptionsSnapshot 也是可以的, 代码如下:

 pub<div style="color:transparent">来源gaodai.ma#com搞##代!^码网</div>lic async Task Invoke(HttpContext context) { var snapshot = context.RequestServices.GetService<IOptionsSnapshot>(); await context.Response.WriteAsync(JsonSerializer.Serialize(snapshot.Value)); }

但是这么做的话, 似乎就偏离了依赖注入的原则了, 因此不推荐这种做法。

总结

以上就是ASP.NET Core中修改配置文件后自动加载新配置的方法详解的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:ASP.NET Core中修改配置文件后自动加载新配置的方法详解

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址