Я успешно написал файл web.config, который позволяет мне выполнять обратный прокси-сервер и отображать его в IFRAME сервера или даже на моем собственном локальном хосте. Ниже следует его сокращенная / отредактированная версия.
<system.webServer>
<rewrite>
<rules>
<rule name="ReverseProxyInboundRule1" stopProcessing="false">
<match url="(.*)" />
<action type="Rewrite" url="https://www.example.com/{R:1}" logRewrittenUrl="true" />
<serverVariables>
<set name="HTTP_X_ORIGINAL_ACCEPT_ENCODING" value="{HTTP_ACCEPT_ENCODING}" />
<set name="HTTP_ACCEPT_ENCODING" value="" />
</serverVariables>
</rule>
<rule name="Capture Origin Header">
<match url=".*" />
<conditions>
<add input="{HTTP_ORIGIN}" pattern=".+" />
</conditions>
<serverVariables>
<set name="CAPTURED_ORIGIN" value="{C:0}" />
</serverVariables>
<action type="None" />
</rule>
</rules>
<outboundRules>
<rule name="Rule1" patternSyntax="Wildcard" stopProcessing="false">
<match serverVariable="RESPONSE_X-Frame-Options" pattern="*" />
<action type="Rewrite" value="" />
</rule>
<rule name="ReverseProxyOutboundRule1" preCondition="ResponseIsTextHtml" stopProcessing="false">
<match filterByTags="None" pattern="^http(s)?://www.example.com/(.*)" />
<action type="Rewrite" value="http{R:1}://thing.our-server.com/{R:2}" />
</rule>
<rule name="RestoreAcceptEncoding" preCondition="NeedsRestoringAcceptEncoding">
<match serverVariable="HTTP_ACCEPT_ENCODING" pattern="^(.*)" />
<action type="Rewrite" value="{HTTP_X_ORIGINAL_ACCEPT_ENCODING}" />
</rule>
<rule name="ContentDam" preCondition="ResponseIsTextHtml">
<match filterByTags="None" pattern="^/(content/dam/.*)" />
<action type="Rewrite" value="https://www.example.com/{R:1}" />
</rule>
<rule name="Set-Access-Control-Allow-Origin for known origins">
<match serverVariable="RESPONSE_Access-Control-Allow-Origin" pattern=".+" negate="true" />
<action type="Rewrite" value="{CAPTURED_ORIGIN}" />
</rule>
<rule name="source srcset" preCondition="ResponseIsTextHtml">
<match filterByTags="CustomTags" customTags="sourceSrcset" pattern=",?\/(content\/dam\/\S+\s\d+w)" />
<action type="Rewrite" value="https://www.example.com/{R:1}" />
</rule>
<rule name="Change GTM" preCondition="ResponseIsTextAnything" patternSyntax="ExactMatch">
<match pattern="GTM-5GFGV2" />
<action type="Rewrite" value="GTM-5XVB5D" />
</rule>
<preConditions>
<preCondition name="ResponseIsTextHtml">
<add input="{RESPONSE_CONTENT_TYPE}" pattern="^text/html" />
</preCondition>
<preCondition name="ResponseIsTextAnything">
<add input="{RESPONSE_CONTENT_TYPE}" pattern="^text/(.+)" />
</preCondition>
<preCondition name="NeedsRestoringAcceptEncoding">
<add input="{HTTP_X_ORIGINAL_ACCEPT_ENCODING}" pattern=".*" />
</preCondition>
</preConditions>
<customTags>
<tags name="sourceSrcset">
<tag name="source" attribute="srcset" />
</tags>
</customTags>
</outboundRules>
</rewrite>
<httpProtocol>
<customHeaders>
<add name="Access-Control-Allow-Origin" value="*" />
</customHeaders>
</httpProtocol>
</system.webServer>
В настоящее время я указываю свой IFRAME на https://thing.our-server.com/
, и обратный прокси принимает путь и строку запроса и передает их запросу на https://www.example.com/
и перезаписывает результаты (более или менее) на this.our-server.com
.
Я бы предпочел, чтобы я мог указать свой IFRAME на https://thing.our-server.com/example/
(плюс путь и запрос), и все работало одинаково.
Однако, когда я вношу следующие изменения, это не работает:
<rule name="ReverseProxyInboundRule1" stopProcessing="false">
<match url="example/(.*)" />
<action type="Rewrite" url="https://www.example.com/{R:1}" logRewrittenUrl="true" />
<serverVariables>
<set name="HTTP_X_ORIGINAL_ACCEPT_ENCODING" value="{HTTP_ACCEPT_ENCODING}" />
<set name="HTTP_ACCEPT_ENCODING" value="" />
</serverVariables>
</rule>
и
<rule name="ReverseProxyOutboundRule1" preCondition="ResponseIsTextHtml">
<match filterByTags="None" pattern="^http(s)?://www.example.com/(.*)" />
<action type="Rewrite" value="http{R:1}://thing.out-server.com/examle/{R:2}" />
</rule>
Я ожидаю, что это неверная спецификация, но я не вижу это на данный момент.