NETCore 讀取JSON配置文件

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;"
  }
}
appsetting.json

jsconfig.jsonweb

{
  "Name": "Joker",
  "Sex": "Man",
  "Describe": "描述",
  "Message": "Hello World - JsConfig - 啊!"
}
jsconfig.json

構造函數注入參數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.jsonjsconfig.json 兩個配置文件會同時生效,同名的值後者優先【jsconfig.json

3.早期Core版本獲取動態配置須要手動指定 reloadOnchange = true,目前3.1已默認配置,只須要使用 Microsoft.Extensions.Options.IOptionsSnapshot 就能夠

相關文章
相關標籤/搜索