使用 Apache 2.2 通过 SSL 连接透明地重写 URL 的最佳方法是什么?

Apache 2 本身不支持 SSL 连接的多个基于名称的虚拟主机,我听说 mod_rewrite 可以帮助解决这个问题。我想做这样的事情:

我已经设置了服务器,以便可以通过

https://secure.example.com/dbadmin

但我想把它作为 https://dbadmin.example.com

如何设置以便重写规则将 dbadmin.example.com 重写为 secure.example.com/dbadmin,但不在客户端的地址栏上显示重写(即客户端仍然只能通过 https 看到 dbadmin.example.com)?

有帮助吗?

解决方案

配置单个 VirtualHost 来同时服务 secure.example.com 和 dbadmin.example.com(使其成为唯一的 *:443 VirtualHost 实现此目的)。然后您可以使用 模组重写 调整 dbadmin.example.com 请求的 URI:

<VirtualHost *:443>
    ServerName secure.example.com
    ServerAlias dbadmin.example.com

    RewriteEngine on
    RewriteCond %{SERVER_NAME} dbadmin.example.com
    RewriteRule !/dbadmin(.*)$ /dbadmin$1
</VirtualHost>

您的 SSL 证书需要对 secure.example.com 和 dbadmin.example.com 均有效。它可以是 Terry Lorber 提到的通配符证书,或者您可以使用 主题替代名称 字段添加其他主机名。

如果您遇到问题,请先将其设置为 <VirtualHost *> 并检查它是否可以在没有 SSL 的情况下工作。SSL 连接和证书是一个单独的复杂层,您可以在 URI 重写工作后进行设置。

其他提示

除非您的 SSL 证书是“通配符”或多站点类型,否则我认为这不起作用。重写将显示在浏览器中,并且地址栏中的名称必须对证书有效,否则您的用户将看到安全错误(他们始终可以接受并继续,但这听起来不像您想要的那样) )。

更多的 这里.

有apaches mod_rewrite,或者你可以设置apache来直接 https://dbadmin.example.com 到服务器上的path/to/example.com/dbadmin

<VirtualHost *>
ServerName subdomain.domain.com
DocumentRoot /home/httpd/htdocs/subdomain/
</VirtualHost>
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top