2

我制作了一个小的 PHP 脚本,它应该允许访问者从我的服务器下载文件。它的工作方式是获取文件之一,获取基本名称并将标头以及文件发送到客户端。

但是,在下载文件时,我有时会得到 index.php,有时会得到 proper_file_name.zip。

我真的不知道为什么它有时会起作用,为什么有时会不起作用。任何建议将不胜感激。

这是我的源代码的相关部分:

// Client requested custom byte range
if(isset($_SERVER['HTTP_RANGE'])) 
{ 
  $range = explode('-', substr($_SERVER['HTTP_RANGE'], 6));
  $seekStart = intval($range[0]);

  if ($range[1] > 0)
    $seekEnd = intval($range[1]);

  header('HTTP/1.1 206 Partial Content');
  header(sprintf('Content-Range: bytes %d-%d/%d', $seekStart, $seekEnd, $size_vfile));
}
else // Set headers for full file
  header('HTTP/1.1 200 OK');

// Get basename of filename
$filename = basename($filename);

// Send headers to client
header('Cache-Control: private');
header('Content-Type: application/octet-stream'); 
header("Content-Disposition: attachment; filename=\"$filename\"");
header('Content-Transfer-Encoding: binary');
header('Content-Description: File Transfer');
header('Content-Length: '.$file_size);
header('Accept-Ranges: bytes');
4

2 回答 2

1

您正在使用基本名称,因此您依赖于您的工作目录。只需在下载文件之前更改到正确的目录

于 2012-09-03T22:23:07.463 回答
1

你清理文件名吗?

并非所有浏览器都接受所有字符。请注意,“将是 100% 保证中断,但其他字符会出现问题。您可能会通过注意未通过的文件名来找出哪些问题会给您带来问题。

您可能希望通过删除任何可能不喜欢的字符来清理 $filename。这里有一些关于它的阅读:http: //greenbytes.de/tech/tc2231/

使用 str_replace() 更改它不喜欢的字符。

于 2012-09-04T00:17:22.207 回答