我正在寻找一个可以管理在 Apache(或 IHS - IBM HTTP Server)上运行的单个域的虚荣网址的工具。
我所说的虚荣网址是指:
www.mycompany.com/ProjectA
将重定向至servera.mycompany.com/whatever
www.mycompany.com/ProjectB
将重定向至serverb.mycompany.com/another/directory
www.mycompany.com/FallCampaign
将重定向至servera.mycompany.com/whatever/offer.html
- 等等等等
目前实施的解决方案包括数千个手动更新的目录,其中包含重定向用户的 php 脚本。这给维护带来了一场噩梦。将此解决方案转换为使用手动更新.htaccess 文件也不是一个选项*。
理想情况下,此工具可以:
- 为 apache/IHS 网络服务器工作
- 为用户和管理员提供 Web 界面
- 允许用户创建、删除和更新虚荣网址
- 允许用户为每个虚荣网址指定区分大小写或不区分大小写
- 允许用户为每个虚荣网址指定重定向为 HTTP 301(永久)或 HTTP 302(临时)
- 允许用户将每个虚荣网址指定为永久的(用于产品)或临时的,并带有“删除”日期(用于营销活动)。
- 提供一个工作流程,让用户提交虚荣网址请求,并让其他人批准
- (作为一种可能的解决方案)写出一个单独的、托管的 .htaccess 文件,前提是该文件在推送到服务器之前已经由该工具验证,这样它就不会对服务器产生负面影响。
- (作为一种可能的解决方案)写出带有重定向/.htaccess 文件的目录,但也会管理创建、更新和删除这些目录。
- 可能使用数据库后端或 xml 后端。
- 以我没有想到的方式提供满足这些标准的解决方案。
- (可选)提供非常简单的报告(永久 URL 的数量、临时 URL 的数量、即将过期的临时 URL 的数量等)
* 使用单个手动编辑的 .htaccess 文件会带来太大的风险,如果文件中出现错误,可能会影响所有 URL。位于目录中的多个 .htaccess 文件与使用 php 重定向一样,都是维护噩梦。
答案1
我不知道您的书中如何准确定义“维护噩梦”,但您可以尝试使用 apache 中的动态重写图:
RewriteEngine on
RewriteMap vanity-map prg:/path/to/vanity.pl
RewriteRule ^/(.*)/(.*)$ /${vanity-map:$1}/$2
vanity.pl 可以是一个简单的 perl 脚本(不要忘记设置$| = 1;
),它获取请求 URL 的第一部分(如上所述)STDIN
并且应该重写它 - 例如通过查询数据库。
现在,只剩下前端了。我是一个没有经验的 Ruby on Rails 程序员(这只是业余爱好),但我认为,如果它不需要看起来很漂亮,我也可以编写一个应用程序来验证用户身份,让他创建重写并将其显示给一些 IT 人员/$WHATEVER 以供批准,时间不到一周,所以我认为任何真正的程序员在几个小时内完成这项工作都不会有问题。根据数据库的不同,甚至可能有可用的前端,只需进行少量自定义即可完成工作(我想到的是 php*admin)。
这样,您就可以获得数据库方法与所有重定向的中央源相结合的所有灵活性。只要 URL 部分的数据库索引适合您的服务器内存,您甚至不必担心性能。
答案2
我只见过反向操作。例如,webmail.domain.tld
重定向到domain.tld/squirrel
。
我不思考您可以通过 DNS 执行您所描述的操作:一旦您将域移到路径中,您就离开了 DNS 处理的范围。
您描述的是 URL 缩短器,例如 TinyURL。但这会涉及您之前描述的相同维护难题。