為什么ASP.NET Core 數(shù)據(jù)庫(kù)連接串的值和appsettings.json配的不一樣?
一、配置讀取順序
ASP.NET Core
中的配置是使用一個(gè)或多個(gè)配置提供程序執(zhí)行的,配置提供程序使用各種配置源從鍵值對(duì)讀取配置數(shù)據(jù)。
ASP.NET Core
提供了大量可用的配置提供程序,這還不包括可以自定義配置提供程序。
添加配置提供程序的順序很重要,因?yàn)楹竺娴奶峁┏绦蛱砑拥呐渲弥祵⒏采w前面的提供程序添加的值。
配置提供程序的典型順序?yàn)椋?/strong>
appsettings.json
appsettings.Environment.json
- 用戶(hù)機(jī)密
- 環(huán)境變量
- 命令行參數(shù)
假如,appsettings.json
配置了開(kāi)發(fā)環(huán)境的數(shù)據(jù)庫(kù)連接串,appsettings.Production.json
配置了生產(chǎn)環(huán)境的數(shù)據(jù)庫(kù)連接串;管理員密碼僅配置在用戶(hù)機(jī)密中。
最終生產(chǎn)環(huán)境的配置為:
鍵 | 來(lái)源 |
---|---|
數(shù)據(jù)庫(kù)連接串 | appsettings.Production.json |
管理員密碼 | 用戶(hù)機(jī)密 |
二、分析
從IConfigurationRoot
接口的文檔上,可以了解到,IConfigurationRoot是表示 IConfiguration 層次結(jié)構(gòu)的根。
使用IConfigurationRoot.Providers
可以得到IEnumerable
,猜測(cè)應(yīng)該是順序排列的。
然后反向遍歷Providers
,讀取配置key對(duì)應(yīng)的值,如果存在那應(yīng)該就是配置的來(lái)源了。
讓我們驗(yàn)證一下。
三、演示
1.讀取Providers
創(chuàng)建WebApplication1,修改Startup.cs,代碼如下:
public Startup(IConfiguration configuration) { ? ? Configuration = (IConfigurationRoot)configuration; } public IConfigurationRoot Configuration { get; } public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { ? ? ...... ? ? app.UseEndpoints(endpoints => ? ? { ? ? ? ? ? ? endpoints.MapGet("/test", async context => ? ? ? ? ? ? { ? ? ? ? ? ? ? ? foreach(var provider in Configuration.Providers) ? ? ? ? ? ? ? ? { ? ? ? ? ? ? ? ? ? ? await context.Response.WriteAsync(provider.ToString()); ? ? ? ? ? ? ? ? ? ? await context.Response.WriteAsync("\r\n"); ? ? ? ? ? ? ? ? } ? ? ? ? ? ? }); ? ? }); ? ?? ? ? ...... }
從下圖看到,順序應(yīng)該是正確的:
2.讀取配置值
繼續(xù)修改Startup.cs,代碼如下:
public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { ? ? ...... ? ? app.UseEndpoints(endpoints => ? ? { ? ? ? ? endpoints.MapGet("/test2/{key:alpha}", async context => ? ? ? ? { ? ? ? ? ? ? var key = context.Request.RouteValues["key"].ToString(); ? ? ? ? ? ? foreach (var provider in Configuration.Providers.Reverse()) ? ? ? ? ? ? { ? ? ? ? ? ? ? ? if (provider.TryGet(key, out string value)) ? ? ? ? ? ? ? ? { ? ? ? ? ? ? ? ? ? ? await context.Response.WriteAsync(provider.ToString()); ? ? ? ? ? ? ? ? ? ? await context.Response.WriteAsync("\r\n"); ? ? ? ? ? ? ? ? ? ? await context.Response.WriteAsync(value); ? ? ? ? ? ? ? ? ? ? break; ? ? ? ? ? ? ? ? } ? ? ? ? ? ? } ? ? ? ? }); ? ? }); ? ?? ? ? ...... }
運(yùn)行后查找AllowedHosts
配置,返回結(jié)果正確。
再次查找AllowedHosts
配置,返回結(jié)果正確。
到此這篇關(guān)于為什么數(shù)據(jù)庫(kù)連接串的值和appsettings.json
配的不一樣?的文章就介紹到這了,更多相關(guān)數(shù)據(jù)庫(kù)連接串的值和appsettings.json配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ASP.NET?Core使用功能開(kāi)關(guān)控制路由訪(fǎng)問(wèn)操作(續(xù))
這篇文章主要介紹了ASP.NET?Core使用功能開(kāi)關(guān)控制路由訪(fǎng)問(wèn)操作的(續(xù)),上一篇文章我們已經(jīng)介紹過(guò)一部份該相關(guān)內(nèi)容,??在本文,我們可以判斷當(dāng)前路由地址是否為調(diào)試地址,讓評(píng)估返回真,需要的小伙伴可以參考一下2022-02-02C#中string與byte[]的轉(zhuǎn)換幫助類(lèi)-.NET教程,C#語(yǔ)言
在寫(xiě)c#程序時(shí),string和byte[]之間的轉(zhuǎn)換比較煩,在移植一些老程序時(shí)感覺(jué)很不好。我在c#中使用des和tripledes時(shí)移植一塊老代碼時(shí)也遇到了同樣的情況。為了下次不為同樣的事情煩惱,就寫(xiě)了下面的幫助類(lèi)。2008-03-03ASP.NET Core MVC 依賴(lài)注入View與Controller
本文重點(diǎn)給大家介紹的是ASP.NET Core MVC 之依賴(lài)注入 View 和ASP.NET Core MVC 之依賴(lài)注入 Controller的相關(guān)資料,需要的小伙伴可以參考下面文章具體內(nèi)容2021-09-09ABP入門(mén)系列應(yīng)用BootstrapTable表格插件
Bootstrap table是一個(gè)開(kāi)源的輕量級(jí)功能非常豐富的前端表格插件。下面通過(guò)本文給大家介紹ABP入門(mén)系列應(yīng)用BootstrapTable表格插件,感興趣的朋友一起學(xué)習(xí)吧2017-03-03.NET??Smobiler的復(fù)雜控件的由來(lái)與創(chuàng)造
這篇文章主要介紹了.NET Smobiler的復(fù)雜控件的由來(lái)與創(chuàng)造,Smobiler的復(fù)雜控件即利用自定義控件的方式組合控件,來(lái)使控件成為一個(gè)有機(jī)整體,里面的控件可相互協(xié)作交互,并使其達(dá)到高可用2022-08-08.NET項(xiàng)目在k8s中運(yùn)行的Dapr持續(xù)集成流程
這篇文章主要介紹了.NET項(xiàng)目在k8s中運(yùn)行的Dapr持續(xù)集成流程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04asp.net core使用DevExtreme20將int列轉(zhuǎn)為checkbox方法示例
這篇文章主要為大家介紹了asp.net core使用DevExtreme20將int列轉(zhuǎn)為checkbox方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08