TOptions接口
net Core 项目有个appsettings.json文件,程序默认也是读取的这个文件,appsettings.json是一个配置文件
我们可以把appsettings.json里面的json字符串映射成实体对象,打开appsettings.json文件,添加如下结构
Info是我新增的,Logging是默认生成的。暂时不管
新增实体类,不区分大小写
ConfigureServices注册
Configuration.GetSection("Info") 是获取appsettings.json文件中的某个节点,跟Info绑定
注册以后,在其他地方就可以通过DI注入使用了,比如:通过构造注入就能获取到数据了
IOptions 依赖命名空间: Microsoft.Extensions.Options;
如果你想在 ConfigureServices 中就使用对象Info呢?那么可以通过Bind方法
Bind方法有两个重载
所以可以这样绑定
上面说了。我们只是获取了appsettings.json中的某个节点,如果想把appsettings.json所有数据
都绑定到Configuration呢?还有一种是这样的结构
用上面的代码就行不通了,要换一种写法:
查看结果发现:info2是没有值的,这样又多了一个Get方法,
热更新IOptionsSnapshot接口
我们知道传统的net,如果修改了Web.Config网站是需要重启的,在net core是支持热更新的
IOptionsSnapshot 接口,也依赖于命名空间: using Microsoft.Extensions.Options
为了测试,我们在修改下构造函数
这样便于对比
ConfigureServices里面不变,加个断点,然后运行项目,目前他们是一样结果
然后我修改下appsettings.json某个字段的值
在次刷新项目,info2的值变了。IDE还用红色突出了这个值变化了
至于IOptions和IOptionsSnapshot有什么区别,我找了只是指出了一个支持热更新,一个不支持
具体内部的代码实现,有兴趣的小伙伴可以去github看源码
刚说了,net core 默认是加载appsettings.json文件,有个参数是可以指定:是否支持热更新
reloadOnChange 参数:如果文件更改,是否应重新加载配置。
当然,这仅仅对支持热更新的IOptionsSnapshot有效
我们也可以手动指定加载这个appsettings.json,当然,如果你手动加载的话,名字可以随便取,不一定叫appsettings.json
当然,约定大于配置,用这个名,一看就知道是配置文件
如果自定义,也就是用ConfigureAppConfiguration注册使用AddJsonFile方法,如果不添加 reloadOnChange
那么默认是false,那么IOptionsSnapshot就不会支持热更新了,具体对比结果我就不截图了