Roy*_*ico 6 .htaccess apache-2.2
我正在寻找一种工具来管理运行在 Apache(或 IHS - IBM HTTP Server)上的单个域的虚 URL。
我所说的虚 URL 是什么意思:
www.mycompany.com/ProjectA 将重定向到
servera.mycompany.com/whateverwww.mycompany.com/ProjectB 将重定向到
serverb.mycompany.com/another/directorywww.mycompany.com/FallCampaign 将重定向到
servera.mycompany.com/whatever/offer.html当前实施的解决方案包含数千个手动更新的目录,其中包含重定向用户的 php 脚本。这是维护的噩梦。将此解决方案转换为使用手动更新的.htaccess 文件的解决方案也不是一种选择*。
理想情况下,该工具将:
* 如果文件中出现错误,使用单个手动编辑的 .htaccess 文件会带来太大风险,可能会影响所有 url。位于目录中的多个 .htaccess 文件与使用 php 重定向是相同的维护噩梦。
我不知道你书中的“维护噩梦”到底是什么定义,但你可以尝试在 apache 中使用动态重写映射:
RewriteEngine on
RewriteMap vanity-map prg:/path/to/vanity.pl
RewriteRule ^/(.*)/(.*)$ /${vanity-map:$1}/$2
Run Code Online (Sandbox Code Playgroud)
vanity.pl 可以是一个简单的 perl 脚本(不要忘记 set $| = 1;),它获取请求 URL 的第一部分(如上所述)STDIN并应该重写它 - 例如通过查询数据库。
现在,只剩下前端了。我是一个没有经验的 Ruby on Rails 程序员(这只是一项业余活动),但我认为,如果不需要看起来漂亮,即使我可以编写一个应用程序来验证用户身份,让他创建重写并显示需要在不到一周的时间内得到一些 IT 人员/$WHATEVER 的批准,所以我认为任何真正的程序员在几个小时内完成这项工作都不会遇到问题。根据数据库的不同,甚至可能有现成的前端,只需一点点定制即可完成工作(我想到了 php*admin)。
通过这种方式,您可以获得数据库方法的所有灵活性以及所有重定向的中央源。只要 URL 部分的数据库索引适合您的服务器内存,您甚至不必担心性能。
| 归档时间: |
|
| 查看次数: |
2381 次 |
| 最近记录: |