您好,登錄后才能下訂單哦!
怎么在.net core中實現一個反向代理中間件?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
Rest請求直接發往.net core程序
如果該請求在.net core程序中實現,則執行請求并返回
如果未實現,將其請求老版接口的數據,并返回結果。
形成如下的一個結構:
試了一下,在.net core中實現這個功能比較簡單,加一個反向代理的中間件即可:
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來反向代理所有未被系統實現的請求即可。
app.Run(Middleware.ReverseProxy.Invoke);
看完上述內容,你們掌握怎么在.net core中實現一個反向代理中間件的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。