ASP.NET Core项⽬默认的配置⽂件是appsettings.json,创建项⽬时就会⾃动⽣成这个文件,我们可以将⼀些配置信息存放在这个配置⽂件中,这样做的好处是当我们修改配置⽂件 时,不在需要重启应⽤,可以实现热更新。
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"AllowedHosts": "*",
"msg": "hello world"
}
IConfiguration
个路由终结点来演⽰如何读取这个配置
app.MapGet("config", (IConfiguration configuration) =>
{
return configuration["msg"] + "_" +
configuration["Logging:LogLevel:Default"];
});
通过IOC注⼊IConfiguration对象,我们就可以访问不同节点的配置了,如果是单层节点, 通过configuration[“msg”]的⽅式进⾏访问,如果是多层级,则通过 configuration[“Logging:LogLevel:Default”]来访问
通过GetValue方法获取
app.MapGet("config", (IConfiguration configuration) =>
{
return configuration.GetValue<string>("msg");
});
GetValue⽆法读取对象,会报异常
通过GetSection方法获取
app.MapGet("config", (IConfiguration configuration) =>
{
return configuration.GetSection("msg").Value;
});
读取对象
app.MapGet("config", (IConfiguration configuration) =>
{
return configuration.GetSection("Person").Get<Person>();
});
使用委托来配置选项
先定义⼀个实体:
public class Person
{
public string Name { get;set; }
public int Age { get;set; }
}
配置如下:
"Person": {
"Name": "张三",
"Age": 18
}
注册配置:
builder.Services.Configure<Person>
(builder.Configuration.GetSection("Person"));
使⽤配置:
app.MapGet("config", (IOptions<Person> options) =>
{
return $"{options.Value.Name},{options.Value.Age}";
});
到此这篇关于ASP.NET读取配置文件的多种方式详解的文章就介绍到这了,更多相关ASP.NET读取配置文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
来源链接:https://www.jb51.net/aspnet/335810844.htm
© 版权声明
本站所有资源来自于网络,仅供学习与参考,请勿用于商业用途,否则产生的一切后果将由您(转载者)自己承担!
如有侵犯您的版权,请及时联系3500663466#qq.com(#换@),我们将第一时间删除本站数据。
如有侵犯您的版权,请及时联系3500663466#qq.com(#换@),我们将第一时间删除本站数据。
THE END











暂无评论内容