怎么在.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中实现一个反向代理中间件的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!