教你如何利用.netcore實(shí)現(xiàn)反向代理中間件的方法-創(chuàng)新互聯(lián)

這篇文章主要給大家介紹了關(guān)于利用.net core實(shí)現(xiàn)反向代理中間件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用.net core具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

最近在將一些項(xiàng)目的rest api遷移到.net core中,最開始是用的Nginx做反向代理,將已經(jīng)完成切換的部分切入系統(tǒng),如下圖所示:

網(wǎng)站的建設(shè)創(chuàng)新互聯(lián)建站專注網(wǎng)站定制,經(jīng)驗(yàn)豐富,不做模板,主營網(wǎng)站定制開發(fā).小程序定制開發(fā),H5頁面制作!給你煥然一新的設(shè)計(jì)體驗(yàn)!已為成都玻璃隔斷等企業(yè)提供專業(yè)服務(wù)。

教你如何利用.net core實(shí)現(xiàn)反向代理中間件的方法

由于遷移過程中也在進(jìn)行代碼重構(gòu),需要經(jīng)常比較頻繁的測試,以保證能及時發(fā)現(xiàn)引入的問題。從而導(dǎo)致我們每遷移一部分都需要配置一次nginx的路由映射,保證遷移的功能能切入系統(tǒng)測試。

進(jìn)行了一段時間后,發(fā)現(xiàn)經(jīng)常配置Nginx一來比較麻煩,二來容易配錯;便想將這個反向代理的功能放在.net core程序中去,實(shí)現(xiàn)如下的功能:

Rest請求直接發(fā)往.net core程序

如果該請求在.net core程序中實(shí)現(xiàn),則執(zhí)行請求并返回

如果未實(shí)現(xiàn),將其請求老版接口的數(shù)據(jù),并返回結(jié)果。

形成如下的一個結(jié)構(gòu):

教你如何利用.net core實(shí)現(xiàn)反向代理中間件的方法

試了一下,在.net core中實(shí)現(xiàn)這個功能比較簡單,加一個反向代理的中間件即可:

public class ReverseProxy
  {
    static HttpClient _http = new HttpClient();
 
    public static async Task Invoke(HttpContext context)
    {
      var url = context.Request.Path.ToUriComponent();
      var uri = new Uri("http://localhost:8080/api" + url);
 
      var request  = CopyRequest(context, uri);
      var remoteRsp = await _http.SendAsync(request);
      var rsp    = context.Response;
 
      foreach (var header in remoteRsp.Headers)
      {
        rsp.Headers.Add(header.Key, header.Value.ToArray());
      }
 
      rsp.ContentType  = remoteRsp.Content.Headers.ContentType?.ToString();
      rsp.ContentLength = remoteRsp.Content.Headers.ContentLength;
 
      await remoteRsp.Content.CopyToAsync(rsp.Body);
    }
 
 
    static HttpRequestMessage CopyRequest(HttpContext context, Uri targetUri)
    {
      var req = context.Request;
      var requestMessage = new HttpRequestMessage()
      {
        Method   = new HttpMethod(req.Method),
        Content  = new StreamContent(req.Body),
        RequestUri = targetUri,
      };
 
      foreach (var header in req.Headers)
      {
        requestMessage.Content?.Headers.TryAddWithoutValidation(header.Key, header.Value.ToArray());
      }
 
      requestMessage.Headers.Host = targetUri.Host;
 
      return requestMessage;
    }
  }

使用起來也比較簡單,放在Configure函數(shù)的最后面,直接使用Run來反向代理所有未被系統(tǒng)實(shí)現(xiàn)的請求即可。

app.Run(Middleware.ReverseProxy.Invoke);

這里我這只是一個比較簡單的實(shí)現(xiàn),大概就二三十行代碼,也不是很完善,但試了一下,基本要的功能也都有,感興趣的朋友可以將其完善下,這個功能本身也只是一個過渡期使用的功能,后續(xù)使用過程中如果有更新也會放上來。

總結(jié)

本文名稱:教你如何利用.netcore實(shí)現(xiàn)反向代理中間件的方法-創(chuàng)新互聯(lián)
URL分享:http://www.muchs.cn/article8/dgieop.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、網(wǎng)站改版、電子商務(wù)、Google、軟件開發(fā)網(wǎng)站營銷

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司