Перезапись URL с помощью UrlRewritingNet завершается неудачно с символом + в URL

Я использую UrlRewritingNet в Umbraco для базового переписывания URL-адресов продуктов и категорий. Все нормально на моей локальной машине (Visual Studio dev-webserver) и на нашем внутреннем сервере разработки (Window Server 2008 с ISS 7, 32 бит). Но происходит сбой на производственном сервере, который является Window Server 2008 R2 с IIS 7 (64-разрядная версия). Симптом заключается в том, что правило перезаписи не запускается. Сервер просто выдает мне ошибку 404.

Правило переписывания выглядит так:

<add name="CategoryRewrite"
     virtualUrl="^/products/(.*)/(.*).aspx"
     rewriteUrlParameter="ExcludeFromClientQueryString"
     destinationUrl="~/default.aspx?umbPage=1&amp;maincategory=$1&amp;subcategory=$2"
     ignoreCase="true"/>

URL выглядит следующим образом - это не работает:

http://example.net/products/category+name/sub+category.aspx

Если я изменю URL-адрес на следующий, он будет работать во всех трех средах:

http://example.net/products/category%20name/sub%20category.aspx

Ясно, что регулярное выражение в атрибуте virtualUrl завершается ошибкой, когда для пробела используется знак +. Но я должен признать, что я могу понять, почему регулярное выражение не работает только на сервере Windows 2008 R2.

Я ищу понимание того, что отличает Windows Server 2008 R2 от двух других сред. Что я должен искать?

Я подтвердил, что System.Web.RegularExpressions.dll является той же версией на серверах.

2 ответа

Решение

Проблема заключается в том, что фильтр запросов IIS7 отклоняет URL-адреса, содержащие символы +. Решением является добавление в ваш Web.config следующего:

<configuration>
 <system.webServer>
  <security>
   <requestFiltering allowDoubleEscaping="true" />
  </security>
 </system.webServer>
</configuration> 

Для дальнейших деталей: http://blogs.iis.net/thomad/archive/2007/12/17/iis7-rejecting-urls-containing.aspx

Коллега получил блестящую идею запустить веб-сайт на своем собственном IIS. А затем ошибка была далее определена как 404.11, и с этого момента решение было простым.

Это кажется мне странным, потому что ваше регулярное выражение также соответствует символам "+". Может быть, проблема в том, что первый символ в регулярном выражении, начало строки '^', которую вы используете. Возможно, на рабочем сервере вы получаете абсолютный URL, а на вашем сервере среды разработки относительный URL-адрес передается в модуль перезаписи.

Другие вопросы по тегам