最近在将一些项目的rest api迁移到.net core中,最开始是用的nginx做反向代理,将已经完成切换的部分切入系统,如下图所示:

由于迁移过程中也在进行代码重构,需要经常比较频繁的测试,以保证能及时发现引入的问题。从而导致我们每迁移一部分都需要配置一次nginx的路由映射,保证迁移的功能能切入系统测试。

进行了一段时间后,发现经常配置nginx一来比较麻烦,二来容易配错;便想将这个反向代理的功能放在.net core程序中去,实现如下的功能:

  1. rest请求直接发往.net core程序
  2. 如果该请求在.net core程序中实现,则执行请求并返回
  3. 如果未实现,将其请求老版接口的数据,并返回结果。

形成如下的一个结构:

试了一下,在.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);

这里我这只是一个比较简单的实现,大概就二三十行代码,也不是很完善,但试了一下,基本要的功能也都有,感兴趣的朋友可以将其完善下,这个功能本身也只是一个过渡期使用的功能,后续使用过程中如果有更新也会放上来。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对www.887551.com的支持。