Asp.NET?Core?WebApi?配置文件詳細(xì)說明
在 ASP.NET Core Web API 中,配置文件(如 appsettings.json)是管理應(yīng)用程序設(shè)置的核心部分。ASP.NET Core 提供了一套靈活的配置系統(tǒng),允許開發(fā)者從多種來源加載配置數(shù)據(jù),并根據(jù)需要使用這些配置。
以下是關(guān)于如何在 ASP.NET Core Web API 中獲取和使用配置文件的詳細(xì)說明:
1. 配置文件的基本結(jié)構(gòu)
默認(rèn)情況下,ASP.NET Core 使用 appsettings.json 文件作為主要的配置文件。以下是一個典型的 appsettings.json 文件示例:
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"AllowedHosts": "*",
"Jwt": {
"Key": "YourSecretKeyForJwtAuthentication",
"Issuer": "YourIssuer",
"Audience": "YourAudience"
},
"Database": {
"ConnectionString": "Server=your-server;Database=your-db;User Id=your-user;Password=your-password;"
}
}Logging:定義日志記錄級別。AllowedHosts:指定允許訪問的主機(jī)。Jwt:JWT 鑒權(quán)相關(guān)的配置(密鑰、簽發(fā)者、受眾等)。Database:數(shù)據(jù)庫連接字符串。
2. 配置文件的加載與綁定
ASP.NET Core 使用 IConfiguration 接口來加載和訪問配置數(shù)據(jù)。以下是配置文件的加載和使用的步驟:
(1) 加載配置文件
在 Program.cs 或 Startup.cs 中,ASP.NET Core 默認(rèn)會加載 appsettings.json 和環(huán)境特定的配置文件(如 appsettings.Development.json)。例如:
var builder = WebApplication.CreateBuilder(args);
WebApplication.CreateBuilder 會自動加載以下內(nèi)容:
appsettings.json- 環(huán)境特定的配置文件(如
appsettings.{Environment}.json) - 環(huán)境變量
- 命令行參數(shù)
(2) 使用 IConfiguration 獲取配置值
builder.Configuration 是一個 IConfiguration 實(shí)例,可以通過它直接訪問配置值。例如:
var jwtKey = builder.Configuration["Jwt:Key"];
var dbConnectionString = builder.Configuration["Database:ConnectionString"];
Console.WriteLine($"JWT Key: {jwtKey}");
Console.WriteLine($"DB Connection String: {dbConnectionString}");(3) 綁定到強(qiáng)類型對象
為了更方便地使用配置,可以將配置綁定到一個強(qiáng)類型的類。例如:
public class JwtSettings
{
public string Key { get; set; }
public string Issuer { get; set; }
public string Audience { get; set; }
}
public class DatabaseSettings
{
public string ConnectionString { get; set; }
}然后通過 GetSection 方法綁定到這些類:
var jwtSettings = builder.Configuration.GetSection("Jwt").Get<JwtSettings>();
var databaseSettings = builder.Configuration.GetSection("Database").Get<DatabaseSettings>();
Console.WriteLine($"JWT Issuer: {jwtSettings.Issuer}");
Console.WriteLine($"DB Connection String: {databaseSettings.ConnectionString}");3. 注冊配置到依賴注入容器
如果需要在多個地方使用配置,可以將配置注冊到依賴注入容器中。例如:
builder.Services.Configure<JwtSettings>(builder.Configuration.GetSection("Jwt"));
builder.Services.Configure<DatabaseSettings>(builder.Configuration.GetSection("Database"));然后在需要的地方通過構(gòu)造函數(shù)注入 IOptions<T> 來使用配置:
using Microsoft.Extensions.Options;
public class AuthService
{
private readonly JwtSettings _jwtSettings;
public AuthService(IOptions<JwtSettings> jwtSettings)
{
_jwtSettings = jwtSettings.Value;
}
public void PrintJwtKey()
{
Console.WriteLine($"JWT Key: {_jwtSettings.Key}");
}
}4. 環(huán)境特定的配置文件
ASP.NET Core 支持基于環(huán)境的配置文件。例如:
- 開發(fā)環(huán)境:
appsettings.Development.json - 生產(chǎn)環(huán)境:
appsettings.Production.json
這些文件會覆蓋 appsettings.json 中的相同配置項(xiàng)。環(huán)境由 ASPNETCORE_ENVIRONMENT 環(huán)境變量決定。
例如,appsettings.Development.json 可能包含開發(fā)環(huán)境特定的配置:
{
"Logging": {
"LogLevel": {
"Default": "Debug"
}
}
}可以通過以下方式檢查當(dāng)前環(huán)境:
if (builder.Environment.IsDevelopment())
{
Console.WriteLine("Running in Development environment");
}
else if (builder.Environment.IsProduction())
{
Console.WriteLine("Running in Production environment");
}5. 其他配置源
除了 appsettings.json,ASP.NET Core 還支持從其他來源加載配置,包括:
(1) 環(huán)境變量
可以通過環(huán)境變量覆蓋配置值。例如:
export Jwt__Key="NewSecretKey"
(2) 命令行參數(shù)
啟動應(yīng)用時通過命令行傳遞參數(shù)。例如:
dotnet run --Jwt:Key="CommandLineKey"
(3) 用戶機(jī)密(Secret Manager)
在開發(fā)環(huán)境中,可以使用 Secret Manager 工具存儲敏感信息,避免將它們提交到版本控制系統(tǒng)中。運(yùn)行以下命令添加用戶機(jī)密:
dotnet user-secrets set "Jwt:Key" "SecretFromUserSecrets"
6. 總結(jié)
ASP.NET Core 的配置系統(tǒng)非常靈活,以下是關(guān)鍵點(diǎn)的總結(jié):
- 默認(rèn)加載:
appsettings.json和環(huán)境特定的配置文件會被自動加載。 - 訪問配置:通過
IConfiguration接口可以直接訪問配置值。 - 綁定到強(qiáng)類型對象:可以將配置綁定到強(qiáng)類型的類,方便使用。
- 注冊到依賴注入:通過
Configure<T>方法將配置注冊到 DI 容器中。 - 多來源支持:支持從環(huán)境變量、命令行參數(shù)、用戶機(jī)密等多種來源加載配置。
通過合理使用配置系統(tǒng),可以讓應(yīng)用程序更加靈活、可維護(hù),并且適配不同的運(yùn)行環(huán)境。
到此這篇關(guān)于Asp.NET Core WebApi 配置文件的文章就介紹到這了,更多相關(guān)Asp.NET Core WebApi 配置文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
asp.net gridview的Rowcommand命令中獲取行索引的方法總結(jié)
asp.net gridview的Rowcommand命令中獲取行索引的方法總結(jié),需要的朋友可以參考下。2010-05-05
ASP.NET MVC5網(wǎng)站開發(fā)我的咨詢列表及添加咨詢(十二)
這篇文章主要為大家詳細(xì)介紹了ASP.NET MVC5網(wǎng)站開發(fā)我的咨詢列表及添加咨詢,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2015-09-09
.NET醫(yī)院公眾號系統(tǒng)線程CPU雙高問題分析
這篇文章主要介紹了.NET醫(yī)院公眾號系統(tǒng) 線程CPU雙高分析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04
.NET讀寫Excel工具Spire.Xls使用 重量級的Excel圖表功能(5)
這篇文章主要為大家詳細(xì)介紹了.NET讀寫Excel工具Spire.Xls使用,重量級的Excel圖表功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11
使用.NET Core實(shí)現(xiàn)餓了嗎拆紅包功能
這篇文章主要介紹了使用.NET Core實(shí)現(xiàn)餓了嗎拆紅包功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07
EF?Core項(xiàng)目中不同數(shù)據(jù)庫需要的安裝包介紹
這篇文章介紹了EF?Core項(xiàng)目中不同數(shù)據(jù)庫需要的安裝包,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05
.NET 解決TabControl 頁里面多余邊距問題經(jīng)驗(yàn)分享
不知道各位同學(xué)有沒有遇到在向TabPage添加內(nèi)容后,里面的東西總是填不滿 TabPage,總是有幾個像素的空白邊距2012-04-04
.Net中關(guān)于stirng轉(zhuǎn)System.Type的一種實(shí)現(xiàn)思路詳解
這篇文章主要給大家介紹了.Net中關(guān)于stirng轉(zhuǎn)System.Type的一種實(shí)現(xiàn)思路的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-05-05

