summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2013-04-01 22:29:48 -0700
committerAndrew Dolgov <[email protected]>2013-04-01 22:29:48 -0700
commit7461774f0f0410e54be9bc06c6abb568cce4c31d (patch)
treeeca4d49f61bff1dda4689b82a96821aba9192680
parentf58df87234089d31ee01b9bcf429131bda29564b (diff)
parent2d0838e6d3e8f15b0f1d62111499ee551935c218 (diff)
Merge pull request #118 from vapier/x-sendfile
add optional support for the X-Sendfile header
-rw-r--r--image.php22
1 files changed, 16 insertions, 6 deletions
diff --git a/image.php b/image.php
index 94cb8e817..dcc7d806d 100644
--- a/image.php
+++ b/image.php
@@ -27,12 +27,22 @@
$filename = CACHE_DIR . '/images/' . $hash . '.png';
if (file_exists($filename)) {
- header("Content-type: image/png");
- $stamp = gmdate("D, d M Y H:i:s", filemtime($filename)). " GMT";
- header("Last-Modified: $stamp", true);
-
- readfile($filename);
-
+ /* See if we can use X-Sendfile */
+ $xsendfile = false;
+ if (function_exists('apache_get_modules') &&
+ array_search('mod_xsendfile', apache_get_modules()))
+ $xsendfile = true;
+
+ if ($xsendfile) {
+ header("X-Sendfile: $filename");
+ header("Content-type: application/octet-stream");
+ header('Content-Disposition: attachment; filename="' . basename($filename) . '"');
+ } else {
+ header("Content-type: image/png");
+ $stamp = gmdate("D, d M Y H:i:s", filemtime($filename)). " GMT";
+ header("Last-Modified: $stamp", true);
+ readfile($filename);
+ }
} else {
header($_SERVER["SERVER_PROTOCOL"]." 404 Not Found");
echo "File not found.";