.NET Core如何进行请求转发的实现

 更新时间:2020-11-19 04:07:26   作者:佚名   我要评论(0)

前言
冒个泡,近日,有关注我公众号的小伙伴私信我,遇到一个问题搞了很久没解决,此问题具有参考意义,这里跟大家分享下,希望对后续可能有需要的你能有所参考和帮

前言

冒个泡,近日,有关注我公众号的小伙伴私信我,遇到一个问题搞了很久没解决,此问题具有参考意义,这里跟大家分享下,希望对后续可能有需要的你能有所参考和帮助。

请求转发问题

内网环境跟外网隔离,现在外网的请求都需要一个专用服务器转接到内网处理,用app.UseRewriter转接, 从外网服务器转发到内网服务器的时候Header 里面的Authorization 居然丢失了,重新设置RewriteContext.HttpContex Header也不行,有没有办法解决?当时我的想法是,实在不行,在外网将token直接放到url或body里不就完事,这样的话,外网每增加一个接口,都得将token取出然后进行转换,内网以相同方式获取,这是小伙伴所不能忍受。这里我们创建两个Web应用程序,然后添加自定义转发规则。首先我们在第一个Web应用程序创建针对如下接口请求转发规则

public class RewriteForwardRules
{
  public static void RedirectRequests(RewriteContext context)
  {
    var request = context.HttpContext.Request;

    if (request.Path.Value.StartsWith("/api/forward", StringComparison.OrdinalIgnoreCase))
    {
      var response = context.HttpContext.Response;

      response.Headers[HeaderNames.Location] = "http://localhost:8091/api/custom";

      context.Result = RuleResult.EndResponse;
    }
  }
}

然后在startup中注入我们自定义转发规则

app.UseRewriter(new RewriteOptions().Add(RewriteForwardRules.RedirectRequests));

当然,如果URL(GET请求)或Body(POST请求)中包含其他参数,将其对应转发写入URL或Body即可,这里token已存储在请求头中,所以我们直接转发请求即可。接下来我们通过Postman模拟外网发出如下POST请求

紧接着,我们在第二个Web应用程序中来接收转发请求,并获取token信息

[HttpPost]
public IActionResult Custom()
{
  var token = Request.Headers[HeaderNames.Authorization].ToString();

  return Ok(token);
}

然后我们一运行,发现结果都没转发到对应内网应用程序,这是为何呢?事实上,转发请求涉及到资源重分配指向另一URL问题,当然我们需要注意的是,既然是转发请求,势必转发者和接受者请求方式必须一致,要不然肯定不行。所以我们必须显式指定重定向状态码,设置为308,如下:

针对状态码308的意思,我们可以参看.NET Core中对于状态码枚举解释: 永久重定向,原始请求方式和目标请求方式必须一致,支持原始请求和目标请求同为GET或POST。 .NET Core中关于此状态码的解释并不那么详细,我们来到专对状态码官方解释( https://httpstatuses.com/308 ),这里我贴下谷歌翻译后的中文:308永久重定向:已为目标资源分配了一个新的永久URI,以后对该资源的任何引用都应使用其中一个URI。具有链接编辑功能的客户端应在可能的情况下自动将对有效请求URI 1的引用重新链接到服务器发送的一个或多个新引用。服务器应在响应中生成一个Location头字段,其中包含新的永久URI的首选URI引用。用户代理可以使用位置字段值进行自动重定向。服务器的响应有效负载通常包含简短的超文本注释,其中包含指向新URI的超链接。默认情况下,308响应可缓存;即,除非方法定义或显式缓存控制。

当然,我们也可以设置状态码为301,301永久移动:已为目标资源分配了一个新的永久URI,以后对该资源的任何引用都应使用其中一个URI。那么状态码301和308到底有何区别呢? 301类似308永久移动,只不过,301不允许将请求方法从GET更改为POST。

总结

  • 请求转发时注意设置状态码为301或308
  • 301类似308永久移动,只不过,301不允许将请求方法从GET更改为POST
  • 基于以上所述,请求转发推荐使用状态码308

到此这篇关于.NET Core如何进行请求转发的实现的文章就介绍到这了,更多相关.NET Core 请求转发内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • ASP.NET Core 奇技淫巧之接口代理转发的实现

相关文章

  • .NET Core如何进行请求转发的实现

    .NET Core如何进行请求转发的实现

    前言 冒个泡,近日,有关注我公众号的小伙伴私信我,遇到一个问题搞了很久没解决,此问题具有参考意义,这里跟大家分享下,希望对后续可能有需要的你能有所参考和帮
    2020-11-19
  • UrlRewrite概念原理及使用方法解析

    UrlRewrite概念原理及使用方法解析

    URL Rewrite即URL重写,就是把传入Web的请求重定向到其他URL的过程。URL Rewrite最常见的应用是URL伪静态化,是将动态页面显示为静态页面方式的一种技术。比如http:
    2020-11-19
  • 在ASP.NET Core5.0中访问HttpContext的方法步骤

    在ASP.NET Core5.0中访问HttpContext的方法步骤

    ASP.NET Core 应用通过 IHttpContextAccessor 接口及其默认实现 HttpContextAccessor 访问 HttpContext。 只有在需要访问服务内的 HttpContext 时,才有必要使用 IH
    2020-11-19
  • .NET或.NET Core Web APi基于tus协议实现断点续传的示例

    .NET或.NET Core Web APi基于tus协议实现断点续传的示例

    前言 前两天我采用技巧式方案基本实现大文件分片上传,这里只是重点在于个人思路和亲身实践,若在实际生产环境要求比较高的话肯定不行,仍存在一些问题需要深入处理
    2020-11-19
  • Docker结合.Net Core的初步使用教程

    Docker结合.Net Core的初步使用教程

    前言 Docker是一项比较流行的容器化技术,可以让开发者将应用以及应用依赖的环境,依赖包一起打包到容器中,然后部署容器到生产环境就可以了,解决了应用程序部署到
    2020-11-19
  • .NET必知的EventCounters性能指标监视器详解

    .NET必知的EventCounters性能指标监视器详解

    在.NET我们对于性能指标监控,其实常见的有两个方法,一个是CLI工具dotnet-counters而另一个是代码级别的EventListener. 使用dotnet-counters dotnet-counters是一个
    2020-11-19
  • .NET Core Web APi大文件分片上传研究实现

    .NET Core Web APi大文件分片上传研究实现

    前言 前两天发表利用FormData进行文件上传,然后有人问要是大文件几个G上传怎么搞,常见的不就是分片再搞下断点续传,动动手差不多也能搞出来,只不过要深入的话,考
    2020-11-19
  • 详解ASP.NET Core 中基于工厂的中间件激活的实现方法

    详解ASP.NET Core 中基于工厂的中间件激活的实现方法

    IMiddlewareFactory/IMiddleware是中间件激活的扩展点。 UseMiddleware扩展方法检查中间件的已注册类型是否实现IMiddleware。如果是,则使用在容器中注册的IMiddlew
    2020-11-19
  • Goland 的安装及激活教程(window、linux下安装)

    Goland 的安装及激活教程(window、linux下安装)

    前言 前面我们已经将GO的环境安装好了,那么是否可以进行开发了呢? 可以,但是为了能够更高效率的开发,我们还需要下载一个软件,该软件的作用就是方便我们能够快速
    2020-11-19
  • 如何使用Goland IDE go mod 方式构建项目

    如何使用Goland IDE go mod 方式构建项目

    不管学习什么编程语言一开始都会经历的四步 开发工具安装 IDE安装 设置 依赖/包 国内镜像 项目构建工具,管理依赖/包 一、Golang 开发工具安装 https://
    2020-11-19

最新评论