ASP.NET?Core?6最小API中使用日志和DI示例詳解
在ASP.NET Core 6的最小API中使用日志和DI
如何在ASP.NET Core 6的最小API中實現(xiàn)日志、從配置系統(tǒng)中讀取并使用依賴注入
ASP.NET Core 6引入了一個簡化的托管模型,可用于實現(xiàn)具有最小依賴性的輕量級API。這些最小的API極大地減少了你需要編寫的模板代碼,以使你的ASP.NET Core 6應(yīng)用程序啟動和運行。
我們在之前的文章中討論了如何開始使用最小API。在這篇文章中,我們將探討最小化API的更多高級方面,包括實現(xiàn)日志、從配置系統(tǒng)中讀取以及使用依賴性注入。
CI/CD?持續(xù)集成和持續(xù)交付解釋
也在InfoWorld上。什么是CI/CD?持續(xù)集成和持續(xù)交付解釋
要使用本文提供的代碼示例,你的系統(tǒng)中應(yīng)該安裝有Visual Studio 2022。如果你還沒有副本,你可以在這里下載Visual Studio 2022。
在Visual Studio 2022中創(chuàng)建一個ASP.NET Core minimal web API項目
首先,讓我們在Visual Studio 2022中創(chuàng)建一個ASP.NET Core項目。按照這些步驟將在Visual Studio 2022中創(chuàng)建一個新的ASP.NET Core Web API 6項目:
- 啟動Visual Studio 2022 IDE
- 點擊 "創(chuàng)建新項目"
- 在 "創(chuàng)建新項目 "窗口,從顯示的模板列表中選擇 "ASP.NET Core Web API";
- 點擊 "下一步"
- 在 "配置你的新項目 "窗口中,指定新項目的名稱和位置
- 根據(jù)你的喜好,可以選擇勾選 "將解決方案和項目放在同一目錄下 "復(fù)選框
- 點擊 "下一步"
- 在接下來顯示的 "附加信息 "窗口中,取消勾選 "使用控制器... "的復(fù)選框,因為在這個例子中我們將使用最小的API。將 "驗證類型 "保留為 "無"(默認(rèn))
- 確保 "啟用Docker"、"為HTTPS配置 "和 "啟用開放API支持 "的復(fù)選框不被選中,因為我們不會在這里使用任何這些功能
- 點擊創(chuàng)建
這將在Visual Studio 2022中創(chuàng)建一個新的ASP.NET Core 6 Web API項目。我們將在本文的后續(xù)章節(jié)中使用這個項目來處理一個最小的API。
運行一個最小的網(wǎng)絡(luò)API
你只需寫幾行代碼就可以讓你的最小API工作:
var builder = WebApplication.CreateBuilder(args); var app = builder.Build(); app.MapGet("/", () => "This is an example of a minimal API"); app.Run();
為一個最小的網(wǎng)絡(luò)API配置多個端口
下面的代碼片斷說明了你如何配置你的最小API在一個特定的端口上運行:
var app = WebApplication.Create(args); app.MapGet("/", () => "Hello World!"); app.Run("http://localhost:5178");
當(dāng)你運行應(yīng)用程序并瀏覽到這個URL時,你應(yīng)該看到 "Hello World!"信息顯示在你的Web瀏覽器中。
你可以通過添加URL來使用多個端口,如下面的代碼片斷所示:
app.Urls.Add("http://localhost:5178"); app.Urls.Add("http://localhost:5179");
在這種情況下,如果你瀏覽到這些端點中的任何一個,都會顯示同樣的 "Hello World!"信息。
你甚至可以從環(huán)境中讀取端口,如下面給出的代碼片斷所示:
var app = WebApplication.Create(args); var port = Environment.GetEnvironmentVariable("PORT") ?? "5155"; app.MapGet("/", () => "Hello World!"); app.Run($"http://localhost:{port}");
在最小的Web API中使用日志記錄
你也可以在你的最小API中使用日志。下面是你如何使用Serilog將數(shù)據(jù)記錄到控制臺:
var logger = new LoggerConfiguration() .WriteTo.Console() .CreateLogger();
你可以使用Serilog來創(chuàng)建日志,使應(yīng)用程序重新啟動時也能持續(xù)。Serilog支持將日志記錄到數(shù)據(jù)庫、文件、云存儲和其他目標(biāo)。下面的代碼片斷說明了你如何在最小的API中使用Serilog:
var builder = WebApplication.CreateBuilder(args); Log.Logger = new LoggerConfiguration() .MinimumLevel.Debug() .WriteTo.File("logs.txt", rollingInterval: RollingInterval.Day) .CreateLogger();
下面的代碼片斷說明了你如何在最小的API中使用日志記錄:
app.MapGet("/", (ILoggerFactory loggerFactory) => { var logger = loggerFactory.CreateLogger("Start"); logger.LogInformation("Starting..."); return "Logging at work!"; });
在最小的API中從配置系統(tǒng)中讀取
你也可以在你的最小的API中從配置系統(tǒng)中讀取。下面的代碼片斷顯示了如何實現(xiàn)這一點:
var app = WebApplication.Create(args); var message = app.Configuration["TextMessage"] ?? "This is a default message."; app.MapGet("/", () => message); app.Run();
在最小的網(wǎng)絡(luò)API中使用依賴性注入
如果你想使用一個HttpClient實例來連接到一個遠(yuǎn)程資源,你可以使用依賴性注入,如下文給出的代碼片段所示:
app.MapGet("/", (IHttpClientFactory httpClientFactory) => "Inside HttpGet method");
記住要使用下面的代碼將HttpClient添加到容器中:
builder.Services.AddHttpClient();
你也可以在HttpPost方法中利用依賴注入的優(yōu)勢。下面的代碼片段顯示了你如何將IHttpClientFactory的一個實例作為參數(shù)傳遞給你的HttpPost方法:
app.MapPost("/", (IHttpClientFactory httpClientFactory) => { var client = httpClientFactory.CreateClient(); return Results.Ok(); });
在一個最小的Web API中注入一個自定義類
你也可以在你的最小API中注入一個自定義類的實例。為了說明這一點,我們來實現(xiàn)兩種類型:IAuthorRepository接口和AuthorRepository類。我們將使用這些類型在我們的最小API中實現(xiàn)依賴性注入。
創(chuàng)建一個名為IAuthorRepository.cs的新文件并插入以下代碼:
public interface IAuthorRepository { public List<Author> GetAuthors(); public Author GetAuthor(int id); }
AuthorRepository類實現(xiàn)了IAuthorRepository接口,如下圖所示:
public class AuthorRepository: IAuthorRepository { private readonly List<Author> _authors; public AuthorRepository() { _authors = new List<Author> { new Author { Id = 1, FirstName = "Joydip", LastName = "Kanjilal" }, new Author { Id = 2, FirstName = "Steve", LastName = "Smith" }, new Author { Id = 3, FirstName = "Julie", LastName = "Lerman" }, new Author { Id = 4, FirstName = "Simon", LastName = "Bisson" } }; } public List<Author> GetAuthors() { return _authors; } public Author GetAuthor(int id) { return _authors.Find(x=> x.Id == id); } }
在最小的網(wǎng)絡(luò)API中注入一個自定義接口
下面的代碼片段說明了你如何注入IAuthorRepository接口的實例:
app.MapGet("api/author/{id:int}", async (IAuthorRepository authorRepository, HttpContext httpContext) => { var id = int.Parse((string)httpContext.Request.RouteValues["id"]); var author = authorRepository.GetAuthor(id); if (author == null) { return Results.NotFound(); } return Results.Ok(author); });
最后,.NET 6包括一個偉大的新功能--全局使用指令。為了利用全局使用,創(chuàng)建一個名為Usings.cs的新文件,并將你所有的使用語句移到那里。你可以在你的ASP.NET Core 6或最小的API中使用這一功能,更多關(guān)于ASP.NET Core 6 API日志DI的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
利用.NET 開發(fā)服務(wù)器 應(yīng)用管理工具
這篇文章主要介紹如何利用.NET 開發(fā)一個應(yīng)用管理工具的服務(wù)器,文章回先聊背景接著其是喲美好方法,需要的的小伙伴可以參考一下小面文章的具體內(nèi)容2021-10-10ASP.NET Web API教程 創(chuàng)建Admin視圖詳細(xì)介紹
現(xiàn)在我們轉(zhuǎn)入客戶端,并添加一個能夠使用從Admin控制器而來的數(shù)據(jù)的頁面。通過給控制器發(fā)送AJAX請求的方式,該頁面將允許用戶創(chuàng)建、編輯,或刪除產(chǎn)品2012-11-11使用Asp.net Mvc3 Razor視圖方式擴展JQuery UI Widgets方法介紹
jquery easyui grid或者extjs grid,jtable的代碼非常簡潔、對于grid功能要求不是很復(fù)雜的情況下,強烈推薦大家使用2012-11-11在?ASP.NET?Core?中為?gRPC?服務(wù)添加全局異常處理
這篇文章主要介紹了在?ASP.NET?Core?中為?gRPC?服務(wù)添加全局異常處理?,在?ASP.NET?Core?中使用?GRPC.ASPNETCore?工具包寫?gRPC?服務(wù),想實現(xiàn)?gRPC?的異常全局?jǐn)r截,下面一起來看看文中的詳細(xì)內(nèi)容吧2022-01-01在 ASP.NET Core 中自動啟用 CAP 事務(wù)詳情
本篇文章旨在描述如何在 ASP.NET Core項目中并以一種簡便的方式啟用CAP事務(wù),因為在我們的示例中都是直接演示比較直觀的方式,沒有進(jìn)行封裝,有些初學(xué)者同學(xué)不太會,找到問我如何封裝,本篇文章主要基于 Entity Framework 來進(jìn)行演示2021-10-10