我在一个解决方案上有+10个域,其中约有一半具有SSL证书。我似乎在创建一个规则以使正确的规则被强制使用https时遇到麻烦。
我可以对他们每个人都做一个规则,但是觉得这应该有效:
<rule name="HTTP to HTTPS redirect 1" patternSyntax="ECMAScript" stopProcessing="true">
<match url="(.*)" />
<conditions>
<add input="{HTTP_HOST}" pattern="^www.domainNo1.dk$" />
<add input="{HTTP_HOST}" pattern="^www.domainNo2.dk$" />
<add input="{HTTP_HOST}" pattern="^www.domainNo3.dk$" />
<add input="{HTTPS}" pattern="off" />
</conditions>
<action type="Redirect" url="https://{HTTP_HOST}/{R:1}" />
</rule>
这不涉及domain4,domain5等。
不幸的是,当我在规则中有多个域时,它不会生效。我猜这可能是默认的逻辑分组:
logicalGrouping="MatchAll"
但是设置:
logicalGrouping="MatchAny"
将使站点根本无法工作。重定向到https后,它将继续重定向页面,从而导致“ ERR_TOO_MANY_REDIRECTS”。
我以为这是由
处理的<add input="{HTTPS}" pattern="off" />
但是没有。
希望任何人都可以提供帮助。
答案 0 :(得分:1)
您可以使用以下重写规则来匹配多个域:
<rule name="http to https with multiple domain name" stopProcessing="true">
<match url="(.*)" />
<conditions logicalGrouping="MatchAll">
<add input="{HTTP_HOST}" pattern="www.sample1.com|www.sample3.com" />
<add input="{HTTPS}" pattern="off" />
</conditions>
<action type="Redirect" url="https://{HTTP_HOST}/{R:1}" />
</rule>
此致
贾尔巴