這篇文章主要給大家介紹了關于利用.net core實現(xiàn)反向代理中間件的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用.net core具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧 |
最近在將一些項目的rest api遷移到.net core中,最開始是用的Nginx做反向代理,將已經完成切換的部分切入系統(tǒng),如下圖所示:
網站的建設創(chuàng)新互聯(lián)建站專注網站定制,經驗豐富,不做模板,主營網站定制開發(fā).小程序定制開發(fā),H5頁面制作!給你煥然一新的設計體驗!已為成都玻璃隔斷等企業(yè)提供專業(yè)服務。由于遷移過程中也在進行代碼重構,需要經常比較頻繁的測試,以保證能及時發(fā)現(xiàn)引入的問題。從而導致我們每遷移一部分都需要配置一次nginx的路由映射,保證遷移的功能能切入系統(tǒng)測試。
進行了一段時間后,發(fā)現(xiàn)經常配置Nginx一來比較麻煩,二來容易配錯;便想將這個反向代理的功能放在.net core程序中去,實現(xiàn)如下的功能:
Rest請求直接發(fā)往.net core程序
如果該請求在.net core程序中實現(xiàn),則執(zhí)行請求并返回
如果未實現(xiàn),將其請求老版接口的數據,并返回結果。
形成如下的一個結構:
試了一下,在.net core中實現(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函數的最后面,直接使用Run來反向代理所有未被系統(tǒng)實現(xiàn)的請求即可。
app.Run(Middleware.ReverseProxy.Invoke);
這里我這只是一個比較簡單的實現(xiàn),大概就二三十行代碼,也不是很完善,但試了一下,基本要的功能也都有,感興趣的朋友可以將其完善下,這個功能本身也只是一個過渡期使用的功能,后續(xù)使用過程中如果有更新也會放上來。
總結