【ASP.NET Core】在 Mini-API 中註入服務

来源:https://www.cnblogs.com/tcjiaan/archive/2023/10/04/17742167.html
-Advertisement-
Play Games

經過版本更新,Mini API 的功能逐步完善,早期支持得不太好的 mini API 現在許多特性都可以用了,比如灰常重要的依賴註入。 咱們先來個相當簡單的註入測試。來,定義一個服務類,為了偷懶,老周這裡就不使用 介面 + 實現類 的方式了。 public class MyService : IDi ...


經過版本更新,Mini API 的功能逐步完善,早期支持得不太好的 mini API 現在許多特性都可以用了,比如灰常重要的依賴註入。

咱們先來個相當簡單的註入測試。來,定義一個服務類,為了偷懶,老周這裡就不使用 介面 + 實現類 的方式了。

public class MyService : IDisposable
{
    public MyService()
    {
        Console.WriteLine($"{nameof(MyService)} 隆重開業");
    }

    public void Dispose()
    {
        Console.WriteLine($"{nameof(MyService)} 即將散伙");
    }

    public void DoSomething()
    {
        Console.WriteLine("正忙著呢……別鬧");
    }
}

此服務類提供給外部調用的公共方法是 DoSomething。

接下來在容器中註冊一下這個服務。

var builder = WebApplication.CreateBuilder(args);
builder.Services.AddScoped<MyService>();
var app = builder.Build();

畢竟,每個 Web API 的調用都是一次消息往返,所以我選擇將服務類註冊為範圍級別的——請求上下文的範圍記憶體活。

最簡單好用的註入方式是讓服務類的實例通過參數傳入。

app.MapGet("/", (MyService sv) =>
{
    // 調用服務類的公共方法
    sv.DoSomething();
    return "三日成精五日成魔七日成鬼";
});

Web API 測試可以不使用第三方工具,dotnet tool 集合有個叫 httprepl 的工具,可以方便使用。此工具需要安裝,命令如下:

dotnet tool install -g microsoft.dotnet-httprepl

安裝完成後,直接在命令終端輸入 httprepl ,回車。就進入了會話模式。假設應用程式的地址是 https://localhost:7249,可以用 connect 命令建立連接。

connect https://localhost:7249

發起請求時,可以用 get、post、put 等命令,對應 HTTP 的請求方式。在上面的例子中,咱們用的是 MapGet 方法註冊的 API,相對路徑是 /。

get /

調用成功後會返迴文本。

而且,MyService 服務也被調用了。

 

接下來咱們改一下代碼,添加一個參數x。

app.MapGet("/", (int x, MyService sv) =>
{
    sv.DoSomething();
    return $"你提交的參數是:{x}";
});

在調用 httprepl 工具時,也可以直接將 URL 作為命令行參數傳給它,能省去使用 connect 命令。

httprepl https://localhost:7249

然後調用一下 API 。

get /?x=150

得到的響應如下:

 

從上面的改動可以知道:來自依賴註入的參數能夠被識別。當然,咱們也可以明確指定各個參數的來源。

app.MapGet("/", ([FromQuery]int x, [FromServices]MyService sv) =>
{
    sv.DoSomething();
    return $"你提交的參數是:{x}";
});

再次運行,再次發出請求。

get /?x=399

 

註入服務在 POST 請求中也可以和作不 body 的參數一起用,例如:

app.MapPost("/send", (Pet p, MyService sv) =>
{
    // 調用服務
    sv.DoSomething();
    string s = string.Format("寵物ID:{0},大名叫{1}", p.ID, p.Name);
    // 返迴文本
    return s;
});

參數 sv 是依賴註入自動賦值的,而參數 p 是 Pet 實例,由HTTP請求的 body 部分提供(預設識別 JSON 格式)。Pet 類定義如下:

public class Pet
{
    public int ID { get; set; }
    public string? Name { get; set; }
}

這個類結構很簡單,兩個成員,用來測試的,不用在意。

在 HttpRepl 工具中可以用 post /send -h content-type=application/json -c ... 的格式提交,-h 指定 HTTP 頭,-c 指定 body 部分。但是,在命令行中用 -c 參數指定 body 很難寫,而且老容易出錯。最好的做法是配置一個文本編輯器。在編輯器中輸入好內容,保存關閉文件,然後 httprepl 工具會自動提交。編輯的文件是臨時文件,由工具生成,我們不用管它,只要在輸入好內容後保存就行。

文本編輯器用啥都行,如記事本。當然,最好設置 VS Code。操作如下:

先進入 httprepl 會話:

httprepl

接著配置 editor.command.default 參數:

pref set editor.command.default "C:\Users\Bug-PC\tools\VSCode\Code.exe"

設置項名稱後面是 VS Code 的路徑。然後,它會提示你最好加上 -w 參數,於是輸入執行:

pref set editor.command.default.arguments "-w"

-w 參數是可以等待 VS Code 響應——等它編輯完關閉後返回 httprepl 工具。

現在,在 httprepl 會話中用 connect 命令連接伺服器。

connect https://localhost:7249

發送 POST 請求。

post /send -h content-type=application/json

註意 Content Type 是 JSON 數據。執行後會啟動 VS Code,然後我們輸入:

{
    "id": 1234,
    "name": "Jack"
}

完成後記得保存文件,並關閉 VS Code。關閉 VS Code 後回到 httprepl 會話,請求自動發送。

 

如果 mini-API 沒有定義接收註入的參數,也可以用 HttpContext 來主動請求服務實例。請看下麵代碼:

app.MapGet("/", (HttpContext context) =>
{
    // 主動請求服務
    MyService sv = context.RequestServices.GetRequiredService<MyService>();
    sv.DoSomething();
    return "我在這裡等了你上萬年了!";
});

只要在所綁定的委托/方法中提供 HttpContext 類型的參數,就可以自動註入。隨後在方法體中就可以直接引用。

這裡要註意:此處咱們不能用 app.Services 去請求服務,因為它引用的是根容器(應用程式最開始創建的),不能訪問生生命周期為 Scoped 的服務。

我們嘗試把服務註冊為單實例,看能不能用 app.Services 來獲取。

var builder = WebApplication.CreateBuilder(args);
builder.Services.AddSingleton<MyService>();
var app = builder.Build();

app.MapGet("/", () =>
{
    // 主動請求服務
    MyService sv = app.Services.GetRequiredService<MyService>();
    sv.DoSomething();
    
    return "我在這裡等了你上萬年了!";
});

運行程式後,在 httprepl 中用 get / 命令測試通過。這說明,單例服務是支持通過 app.Services 獲取的。不過,MyService 實例要等到應用程式結束時才會釋放。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 這些練習題是在神經網路與深度學習課程上老師提供的,原因是有些同學沒學過python,作為簡單的練手習題。題目都很簡單,加上python本身也比較簡單,有些題目的作答可以一行代碼實現(雖然可讀性就下降了)。 ...
  • Bus 簡介 Spring Cloud Bus 是 Spring Cloud 體系內的消息匯流排,支持 RabbitMQ 和 Kafka 兩種消息中間件。所謂消息匯流排,簡單理解就是一個消息中心,眾多微服務實例都可以連接到匯流排上,實例可以往消息中心發送或接收信息,例如:實例 A 發送一條消息到匯流排上,總 ...
  • Java基礎語法 目錄1. 概述1.1. 語言特性1.2. 開發平臺1.3. 開發環境1.4. 開發步驟1.5. 註釋2. 變數與運算符2.1. 關鍵字/保留字2.2. 標識符2.3. 變數2.4. 常用數據類型2.4.1. 基本數據類型(8種)2.4.2. 引用數據類型2.4.3. 數據類型轉換2 ...
  • C++的 bitset 在 bitset 頭文件中,它是一種類似數組的結構,它的每一個元素只能是0或1,每個元素僅用1bit空間。 下麵是具體用法 構造函數 bitset常用構造函數有四種,如下 bitset<4> bitset1; //無參構造,長度為4,預設每一位為0 bitset<8> bit ...
  • AOP(Aspect Oriented Programming,面向切麵編程),通過預編譯方式和運行期動態代理實現程式功能的統一維護的一種技術。 ...
  • 在每個Java新版本發佈的特性中,都會包含一些Preview(預覽)功能,這些功能主要用來給開發者體驗並收集建議。所以,Preview階段的功能並不是預設開啟的。 如果想體驗某個Java版本中的Preview功能,您還需要做一些設置才能把程式跑起來。 下麵以IDEA 2023.2為例,演示為Java ...
  • 當讀者需要獲取到特定進程內的寄存器信息時,則需要在上述代碼中進行完善,首先需要編寫`CREATE_PROCESS_DEBUG_EVENT`事件,程式被首次載入進入記憶體時會被觸發此事件,在該事件內首先我們通過`lpStartAddress`屬性獲取到當前程式的入口地址,並通過`SuspendThrea... ...
  • 1. 簡介 機緣巧合下寫的一個工程,本來是作為商家視覺識別上位機的替代品,但是最後沒用上,因此只開發了一半(廠家升級了攝像頭和軟體) 該工程基於WPF的.net6+mvvm 調用攝像頭進行識別 opencv開攝像頭(不想自己封裝win32api),yolov5對圖像進行檢測 2.引用庫 MVVM C ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...