Попробуйте переписать на другой URL, если это приведет к 404
У меня есть локальный сервер Tomcat, который я разрабатываю для использования моего локального экземпляра IIS в качестве прокси.
Я делаю это потому, что развертывание сервера является болезненным процессом, так как большая часть контента не является (что я бы назвал это) автономной. Содержимое разных проектов по существу копируется в корень сервера. Я не хотел иметь дело с такой сложностью его настройки, поэтому с помощью модуля перезаписи я мог переписывать URL-адреса в виртуальные каталоги по большей части.
например,
/js/* -> /someproject/js/*
/css/* -> /someproject/css/*
/**/*.pdf -> /someotherproject/pdf/*
Однако есть несколько угловых случаев, когда эта схема не работает, особенно когда в каталогах назначения есть наложение. При развертывании некоторые ресурсы размещаются в одном и том же каталоге, поэтому нет никакого реального способа определить, какой именно. В этих файлах нет строгой закономерности, все смешанное.
например,
/someproject1/file1.txt -> /file1.txt
/someproject2/book2.doc -> /book2.doc
Так, учитывая URL /file1.txt
Я не знаю, могу ли я переписать, чтобы перейти к someproject1
или же someproject2
, Так что я думаю, я мог бы заставить это работать, если бы была какая-то иерархия того, к чему URL пытаться переписать. Так что я мог бы взять URL как /file3.txt
Перепишите первый из этих шаблонов, который кажется действительным.
/someproject1/file3.txt # if 404, try the next
/someproject2/file3.txt # if 404, try the next
/someotherproject/file3.txt # if 404, try the next
/file3.txt # fallback
Это можно выразить только с помощью модуля перезаписи URL?
1 ответ
Я смог заставить это работать.
Первым препятствием было то, что я не осознавал, что не все типы условных совпадений доступны в глобальной области действия (где я писал свои правила). Только Pattern
был доступен. Мне пришлось изменить область на "распределенную" область (правила для сайта), чтобы получить доступ к IsFile
а также IsDirectory
типы совпадений.
Затем я мог написать свои правила с какой-то иерархией. Сначала переписать, чтобы соответствовать шаблону, который я хочу сначала попробовать, затем, если он не разрешается в файл, переписать его на следующий шаблон и повторить.
<rule name="try in project/content" stopProcessing="false">
<match url=".*" />
<action type="Rewrite" url="project/content/{R:0}" />
</rule>
<rule name="verify project/content" stopProcessing="false">
<match url="(project)/content(/.*)" />
<conditions logicalGrouping="MatchAll">
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
</conditions>
<action type="Rewrite" url="{R:1}{R:2}" />
</rule>
В моем конкретном случае я хотел сначала попробовать определенный подкаталог, а затем попробовать родительские каталоги, если они не существуют. Но теоретически я мог бы сделать это для любого набора путей, если я знаю, в каком порядке их пробовать.
Так что для моего примера в вопросе я бы установил эти правила:
<rule name="try in someproject1" stopProcessing="false">
<match url=".*" />
<action type="Rewrite" url="someproject1/{R:0}" />
</rule>
<rule name="try in someproject2 otherwise" stopProcessing="false">
<match url="someproject1/(.*)" />
<conditions logicalGrouping="MatchAll">
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
</conditions>
<action type="Rewrite" url="someproject2/{R:1}" />
</rule>
<rule name="try in someotherproject otherwise" stopProcessing="false">
<match url="someproject2/(.*)" />
<conditions logicalGrouping="MatchAll">
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
</conditions>
<action type="Rewrite" url="someotherproject/{R:1}" />
</rule>
<rule name="fallback to root otherwise" stopProcessing="false">
<match url="someotherproject/(.*)" />
<conditions logicalGrouping="MatchAll">
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
</conditions>
<action type="Rewrite" url="{R:1}" />
</rule>