基于文章在 Web API 中使用 SSL,我实现了一个授权过滤器,以要求 SSL 用于 Web API (2.1) 控制器的方法:
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, Inherited = true,
AllowMultiple = false)]
public sealed class RequireHttpsAttribute : AuthorizationFilterAttribute
{
public override void OnAuthorization(HttpActionContext actionContext)
{
if (actionContext.Request.RequestUri.Scheme != Uri.UriSchemeHttps)
{
actionContext.Response = new HttpResponseMessage(HttpStatusCode.Forbidden)
{
ReasonPhrase = "HTTPS Required"
};
}
else
{
base.OnAuthorization(actionContext);
}
}
}
这工作正常 - 在某些 Web 服务器上。如果将 Web Farm Framework (WFF) 用作反向代理,它可能会失败(通过阻止有效的 HTTPS 请求)。
WFF 添加了 header X-Forwarded-Proto
,这是反向代理的事实标准。
如何修改此代码以使用或不使用标准代理?