测试X-Sendfile头是否正常工作

dal*_*per 8 php wordpress fastcgi x-sendfile cherokee

我正在寻找一种方法来确认X-Sendfile是否正确处理由脚本(PHP)返回给Web服务器的请求.图像正在正确提供,但我想我会在curl请求中看到标题.

$ curl -I http://blog2.stageserver.net/wp-includes/ms-files.php?file=/2011/05/amos-lee-feature.jpg
HTTP/1.1 200 OK
Date: Wed, 04 Jan 2012 17:19:45 GMT
Server: Cherokee/1.2.100 (Arch Linux)
ETag: "4dd2e306=9da0"
Last-Modified: Tue, 17 May 2011 21:05:10 GMT
Content-Type: image/jpeg
Content-Length: 40352
X-Powered-By: PHP/5.3.8
Content-Disposition: inline; filename="amos-lee-feature.jpg"
Run Code Online (Sandbox Code Playgroud)

组态

在FastCGI中使用PHP-FPM 5.3.8的Cherokee 1.2.100 :(
cherokee.conf: vserver!20!rule!500!handler!xsendfile = 1
由vServer> Behavior> Extensions设置php> Handler:允许X-Sendfile [check Enabled])

Wordpress网络/ WPMU 3.3.1:
define('WPMU_SENDFILE',true);在包含wp-config.php之前设置如下wp-settings.php.这将触发以下代码在WP的wp-includes/ms-files.php中执行:50为特定博客提供文件:

header( 'X-Sendfile: ' . $file );
exit;
Run Code Online (Sandbox Code Playgroud)

我已经确认上面的代码片段正在通过在exit();调用之前添加一个用于处置的附加标头来执行.Content-Disposition与curl结果一起出现,而不是最初在ms-files.php代码中.添加的代码是:
header('Content-Disposition: inline; filename="'.basename($file).'"');


研究

我有:

  • 进行配置更改后重新启动php-fpm/cherokee守护程序.
  • php.net/readfile的注释中尝试了几个技巧,并用ms-files.php示例中更完整的代码替换了简单的头文件.
    • php.net/manual/en/function.readfile.php
    • www.jasny.net/articles/how-i-php-x-sendfile/
    • *codeutopia.net /博客/ 2009/03/06 /送文件,更好,Apache的mod_xsendfile及PHP/*
  • 确认[切诺基支持] [5]并测试[有和没有] [6]压缩,即使我不认为它会适用,因为我的图像正确服务.我还从lighttpd帖子中发现了一个可疑的类似问题.
    • *cherokee-project.com/DOC/other_goodies.html*
    • code.google.com/p/cherokee/issues/detail?id=1228
    • webdevrefinery.com/forums/topic/4761-x-sendfile/
  • 在SO上找到一个模糊,可能表示标题被剥离
    • stackoverflow.com/questions/7296642/django-understanding-x-sendfile
  • 测试上面的标题与curl,wget,Firefox,Chrome和web-sniffer.net是一致的.
  • 发现我由于缺乏声誉而无法发布超过2个链接.

问题

  • X-Sendfile当标题正常工作或被删除时,它会出现在标题中吗?
  • 是否可以使用访问日志来确定是否X-Sendfile有效?

我在这里寻找一般的故障排除技巧或信息,不一定特定于PHP/Cherokee.

更新

我找到了一种在测试或沙箱环境中确认X-Sendfile或X-Accel-Redirect的合适方法:禁用X-Sendfile并检查标头.

在Cherokee中禁用允许X-Sendfile:

$ curl -I http://blog2.stageserver.net/wp-includes/ms-files.php?file=/2011/05/amos-lee-feature.jpg
HTTP/1.1 200 OK
Date: Fri, 06 Jan 2012 15:34:49 GMT
Server: Cherokee/1.2.101 (Ubuntu)
X-Powered-By: PHP/5.3.6-13ubuntu3.3
Content-Type: image/jpeg
X-Sendfile: /srv/http/wordpress/wp-content/blogs.dir/2/files/2011/05/amos-lee-feature.jpg
Content-Length: 40352
Run Code Online (Sandbox Code Playgroud)

图像不会在浏览器中加载,但您可以看到标题存在.重新启用允许X-Sendfile后,图像加载,您可以确信X-Sendfile正在运行.

Mae*_*lyn 0

根据github 上的源代码, X-Sendfile 标头将被删除。

如果我正确地浏览了文件,那么只有在调试模式下编译它时才会记录成功。