我有以下规则,它可以很好地将我的www请求重定向到根目录。
然而,我似乎无法为localhost关闭它。这是我现在所拥有的:
<rule name="CanonicalHostNameRule1">
<match url="(.*)" />
<conditions>
<add input="{HTTP_HOST}" pattern="^example\.com$" negate="true" />
</conditions>
<action type="Redirect" url="https://example.com/{R:1}" />
</rule>
我试过很多方法,包括:
<rule name="CanonicalHostNameRule1">
<match url="(.*)" />
<conditions>
<add input="{HTTP_HOST}" pattern="^localhost$" negate="true" />
<add input="{HTTP_HOST}" pattern="^example\.com$" negate="true" />
</conditions>
<action type="Redirect" url="https://example.com/{R:1}" />
</rule>
你能帮忙吗?可惜,正则表达式是我的弱点。
发布于 2018-06-07 09:59:06
如果使用一个条件来只匹配以www.
开头的请求,而不是在不希望应用规则时尝试进行否定,情况会怎样呢?这避免了否定localhost
的需要,因为localhost
永远不会在以下条件中匹配:
<rule name="Strip WWW" stopProcessing="true">
<match url="(.*)" />
<conditions>
<add input="{HTTP_HOST}" pattern="^www\.(.*)" />
</conditions>
<action type="Redirect" url="https://{C:1}/{URL}" />
</rule>
但是,您尝试的规则示例(第二个代码块)也适用于我在Windows10VM上使用IIS进行测试。我可以在不重定向的情况下浏览localhost
。也许这里还有另一个问题。
https://stackoverflow.com/questions/50675414
复制相似问题