AppSetting.jsonmysql
{ "Logging": { "LogLevel": { "Default": "Information", "Microsoft": "Warning", "Microsoft.Hosting.Lifetime": "Information" } }, "AllowedHosts": "*", "Title": "Hello World!", "Message": "Hello World - AppSetting - 啊!", "ConnectionStrings": { "Mysql": "server=localhost;port=3306;userid=root;pwd=123456;database=testefdb", "MsSql": "Data Source=.;Initial Catalog=testefdb;User Id=root;Password=123456;" } }
jsconfig.jsonweb
{ "Name": "Joker", "Sex": "Man", "Describe": "描述", "Message": "Hello World - JsConfig - 啊!" }
構造函數注入參數sql
public IConfiguration Configuration { get; } public Startup(IConfiguration configuration) { Configuration = configuration; }
獲取配置文件參數json
1.獲取指定key的值app
var title = Configuration["Title"]; var mysql = Configuration["ConnectionStrings:Mysql"];
2.綁定配置模型對象ide
// 獲取全部配置 var appSetting = new MyAppSetting(); Configuration.Bind(appSetting); var loggerDefault = appSetting.Logging.LogLevel.Default; // 獲取指定節點配置 var connectionstrings = new Connectionstrings(); Configuration.GetSection("ConnectionStrings").Bind(connectionstrings); var mssql = connectionstrings.MsSql;
3.註冊配置選項的服務函數
3.1.在 Startup/ConfigureServices 註冊配置選項服務ui
// 註冊配置選項服務 services.Configure<MyAppSetting>(Configuration); // 註冊 自定義配置信息 var config = new ConfigurationBuilder().AddJsonFile("jsconfig.json", true, true).Build(); var name = config["Name"]; services.Configure<MyJsConfig>(config);
3.2.在 Startup/Configure 獲取配置spa
public void Configure(IOptions<MyAppSetting> appSettingOptions, IOptionsSnapshot<MyJsConfig> myJsConfigoptions) { // 讀取 配置信息【appsettings.json】 var loggerMicrosoft = appSettingOptions.Value.Logging.LogLevel.Microsoft; // 讀取 自定義配置信息【jsconfig.json】 var describe = myJsConfigoptions.Value.Describe; }
*注:code
1.在 Startup/ConfigureServices 經過 AddJsonFile 註冊自定義配置信息,使用IOptionsSnapshot【站點啓動後,每次獲取到的值都是配置文件裏的最新值】沒有效果,須要在 Program/CreateHostBuilder 中進行配置【有知道的大佬求解釋】
public static IHostBuilder CreateHostBuilder(string[] args) { // 建立默認Builder,完成各類基礎配置: Host.CreateDefaultBuilder 已註冊 appsetting.json IHostBuilder hostBuild = Host.CreateDefaultBuilder(args); // 配置默認WebHost hostBuild.ConfigureWebHostDefaults(webBuilder => { webBuilder.UseStartup<Startup>(); }); hostBuild.ConfigureAppConfiguration(configBuilder => { // 註冊 自定義配置信息,reloadOnChange:若是文件更改,是否應從新加載配置 configBuilder.AddJsonFile("jsconfig.json", true, reloadOnChange: true); }); return hostBuild; }
2.appsetting.json 和 jsconfig.json 兩個配置文件會同時生效,同名的值後者優先【jsconfig.json】
3.早期Core版本獲取動態配置須要手動指定 reloadOnchange = true,目前3.1已默認配置,只須要使用 Microsoft.Extensions.Options.IOptionsSnapshot 就能夠