2

我正在尝试使用 apache mod_include。

我有两台运行 apache 的服务器:我试图在我的 test_local.shtml (server1) 中包含一些来自 test_remote.shml (server2) 的简单文本。

test_local.shtml

<html>
  <head>
  <title></title>
  </head>
  <body>
    <!--#include virtual="http://www.server2.com/test_remote.shtml"-->
  </body>
</html>

test_remote.shtml

<b>this is a test</b>

起初它不起作用(在error_log中出现“文件不存在”错误)。看起来出于安全原因,我设法包含的唯一文件位于我的本地服务器(server1)上,具有本地路径,但没有远程 url。然后我明白我需要将 mod_proxy(和 mod_proxy_html)与 mod_include 结合使用才能使远程包含工作。

所以我将以下内容添加到我的 httpd.conf(在 server1 上):

ProxyPass /server2 http://www.server2.com

然后我将 test_local.shtml 中的包含行更改为:

<!--#include virtual="/server2/test_remote.shtml"-->

这次没有错误,包含了一些内容,但生成的文本都是乱码:

 ‹³I²+ÉÈ,V¢D…’Ôâý$;.j¿è

我的配置中是否缺少某些内容?怎么了?

更新:我怀疑这与两台服务器之间发送(然后读取)数据的方式有关..例如压缩或类似。我检查了 mod_deflate 配置部分,它包含在两个服务器中并在两个服务器中工作,它是相同的。任何的想法?谢谢

更新 2:在 server2 上禁用 SetOutputFilter DEFLATE,在 server1 上包含 mod_include 的文本是完全可读的。所以这就是问题的根源:如何配置 server1 来处理 gzip 压缩的内容并正确显示?(假设我会想象某种与输出过滤器相反的输入过滤器..)

4

1 回答 1

2

我找到了两种解决方案,但我更喜欢第二种,因为它不需要更改远程服务器的配置。

解决方案1:

通过将以下内容添加到远程服务器配置,我们禁用 .shtml 文件的 gzip 压缩:

<IfModule mod_deflate.c>
    SetEnvIfNoCase Request_URI \.shtml$ no-gzip dont-vary
</IfModule>

这对我来说不是最好的解决方案,因为我并不总是可以访问包含内容的远程服务器。

解决方案2:

在“本地”服务器(使用 SSI 包含的托管页面)上,添加以下内容:

ProxyPass /server2 http://www.server2.com/
ProxyPassReverse /server2 http://www.server2.com/
<Location "/server2/">
    RequestHeader unset Accept-Encoding
</Location>

基本上,我告诉 Apache 禁用 Accept-Encoding 请求标头;当向远程服务器请求 .shtml 页面时,我们会询问没有压缩的页面。因此,我们得到纯文本,避免了乱码内容。

更多信息:http ://wiki.apache.org/httpd/ReInflating

于 2013-02-20T09:45:23.517 回答