<强>这篇文章主要给大家介绍了关于利用。net核心实现反向代理中间件的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用。net核心具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧强>
最近在将一些项目的rest api迁移到。net核心中,最开始是用的Nginx做反向代理,将已经完成切换的部分切入系统,如下图所示:
由于迁移过程中也在进行代码重构,需要经常比较频繁的测试,以保证能及时发现引入的问题。从而导致我们每迁移一部分都需要配置一次nginx的路由映射,保证迁移的功能能切入系统测试。
进行了一段时间后,发现经常配置Nginx一来比较麻烦,二来容易配错,便想将这个反向代理的功能放在。net核心程序中去,实现如下的功能:
休息请求直接发往。net核心程序
如果该请求在。net核心程序中实现,则执行请求并返回
如果未实现,将其请求老版接口的数据,并返回结果。
形成如下的一个结构:
试了一下,在。net核心中实现这个功能比较简单,加一个反向代理的中间件即可:
<>以前public class  ReverseProxy {才能 ,,,static HttpClient _http =, new HttpClient (); , ,,,public static async Task 调用(HttpContext 上下文) ,,,{ ,,,,,var url =, context.Request.Path.ToUriComponent (); ,,,,,var uri =, new Uri (“http://localhost: 8080/api", +, url); , ,,,,,var request ,=, CopyRequest(上下文,uri); ,,,,,var remoteRsp =, await _http.SendAsync(请求); ,,,,,var rsp ,,,=, context.Response; , ,,,,,foreach (var header  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 上下文,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  req.Headers拷贝) ,,,,,{ ,,,,,,,requestMessage.Content ? .Headers.TryAddWithoutValidation (header.Key, header.Value.ToArray ()); ,,,,,} , ,,,,,requestMessage.Headers.Host =, targetUri.Host; , ,,,,,return requestMessage; ,,,} }>之前才能使用起来也比较简单,放在配置函数的最后面,直接使用跑步来反向代理所有未被系统实现的请求即可。
<>以前app.Run (Middleware.ReverseProxy.Invoke);这里我这只是一个比较简单的实现,大概就二三十行代码,也不是很完善,但试了一下,基本要的功能也都有,感兴趣的朋友可以将其完善下,这个功能本身也只是一个过渡期使用的功能,后续使用过程中如果有更新也会放上来。
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值。
原文地址: https://www.linuxprobe.com/linux-net-core.html