原文連接:blog.zhuliang.ltd/back-end/co…web
如下示例基於 .net core 2.2json
asp.net mvc已經內部實現了對配置appsettings.json文件的使用,builder默認支持熱更新。數組
假設appsettings.json內容爲:mvc
{
"Logging": {
"LogLevel": {
"Default": "Warning"
}
},
"AllowedHosts": "*"
}
複製代碼
namespace webapp.Models
{
public class AppsettingsModel
{
public Logging Logging { get; set; }
public string AllowedHosts { get; set; }
}
public class Logging
{
public LogLevel LogLevel { get; set; }
}
public class LogLevel
{
public string Default { get; set; }
}
}
複製代碼
public void ConfigureServices(IServiceCollection services) {
services.Configure<CookiePolicyOptions>(options =>
{
options.CheckConsentNeeded = context => true;
options.MinimumSameSitePolicy = SameSiteMode.None;
});
// 依賴注入
services.Configure<AppsettingsModel>(Configuration);
services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
}
複製代碼
public class TestController : Controller
{
private readonly AppsettingsModel _appsettingsModel;
//若要使用熱更新,則入參調整爲 IOptionsSnapshot<T>
public TestController(IOptions<AppsettingsModel> appsettingsModel) {
_appsettingsModel = appsettingsModel.Value;
}
public IActionResult Index() {
return View("Index", _appsettingsModel.Logging.LogLevel.Default);
}
}
複製代碼
假設測試controller爲app
public class TestController : Controller
{
private readonly AppsettingsModel _appsettingsModel;
//使用的是:IOptionsSnapshot<T>
public TestController(IOptionsSnapshot<AppsettingsModel> appsettingsModel) {
_appsettingsModel = appsettingsModel.Value;
}
public IActionResult Index() {
return View("Index", _appsettingsModel.Logging.LogLevel.Default);
}
}
複製代碼
public class Program
{
public static void Main(string[] args) {
CreateWebHostBuilder(args).Build().Run();
}
public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
WebHost.CreateDefaultBuilder(args)
.ConfigureAppConfiguration((context, config) => //1.經過該方法來覆蓋配置
{
//2.從新添加json配置文件
config.AddJsonFile("appsettings.json", false, false); //3.最後一個參數就是是否熱更新的布爾值
})
.UseStartup<Startup>();
}
複製代碼
對於console項目,默認是沒有這個dll的,須要自行從nuget安裝asp.net
從nuget中安裝:Microsoft.AspNetCore.All (注意,末尾不是dll,而是all)webapp
在項目中引入:Microsoft.Extensions.Configuration; 並使用ConfigurationBuilder來構建配置。測試
在控制檯項目屬性中增長name和class參數:ui
使用:spa
class Program
{
static void Main(string[] args) {
var builder = new ConfigurationBuilder()
.AddCommandLine(args);
var configuration = builder.Build();
Console.WriteLine($"name:{configuration["name"]}"); //name:CLS
Console.WriteLine($"class:{configuration["class"]}"); //class:Class_A
Console.Read();
}
}
複製代碼
class Program
{
static void Main(string[] args) {
var dict = new Dictionary<string, string>
{
{"name","MC"},
{"class","CLASS_MC"}
};
var builder = new ConfigurationBuilder()
// .AddCommandLine(args)
.AddInMemoryCollection(dict);
var configuration = builder.Build();
Console.WriteLine($"name:{configuration["name"]}");//name:MC
Console.WriteLine($"class:{configuration["class"]}"); //class:CLASS_MC
Console.Read();
}
}
複製代碼
注意事項:
/* 假設 在項目屬性中,定義的內容爲:name=CLS,class=CLASS_CLS,grade="mygrade" 在代碼中,dict的內容爲:name=MC,class=CLASS_MC */
//對於代碼:
var builder = new ConfigurationBuilder()
.AddCommandLine(args)
.AddInMemoryCollection(dict);
var configuration = builder.Build();
Console.WriteLine($"name:{configuration["name"]}");//name:MC
Console.WriteLine($"class:{configuration["class"]}"); //class:CLASS_MC
Console.WriteLine($"grade:{configuration["grade"]}"); //grade:mygrade
//對於代碼:
var builder = new ConfigurationBuilder()
.AddInMemoryCollection(dict)
.AddCommandLine(args);
var configuration = builder.Build();
Console.WriteLine($"name:{configuration["name"]}");//name:CLS
Console.WriteLine($"class:{configuration["class"]}"); //class:CLASS_CLS
Console.WriteLine($"grade:{configuration["grade"]}"); //grade:mygrade
複製代碼
dotnet CommandLineSample.dll name=111 class=222 grade="my grade"
複製代碼
JSON文件內容:
{
"Class": "Class A",
"PersonInfo": {
"name": "my name",
"age": "12"
},
"Hobbies": [
{
"Type": "Family",
"HobbyName": "Piano"
},
{
"Type": "Personal",
"HobbyName": "Singing"
}
]
}
複製代碼
static void Main(string[] args) {
var builder = new ConfigurationBuilder()
.AddJsonFile("jsconfig1.json");
var configuration = builder.Build();
Console.WriteLine($"name:{configuration["PersonInfo:name"]}");
Console.WriteLine($"class:{configuration["class"]}");
Console.WriteLine($"age:{configuration["PersonInfo:age"]}");
//注意下調用參數時的格式:"{參數Key}:{數組索引}:{子項參數Key}"
Console.WriteLine($"FamilyHobby:{configuration["Hobbies:0:HobbyName"]}");
Console.WriteLine($"PersonalHobby:{configuration["Hobbies:1:HobbyName"]}");
Console.Read();
}
複製代碼