php ファイルのダウンロードに失敗するのは、readfile がファイルを読み取るときにファイルがキャッシュに置かれ、メモリ オーバーフローが発生するためです。解決策は、セグメント化されたダウンロードを実装し、ダウンロード速度を制限することです。
推奨: 「PHP ビデオ チュートリアル 」
PHP による大きなファイルのダウンロードの失敗とダウンロードの制限を解決する速度
1. 問題:
PHP が readfile 関数を使用してダウンロード ファイルを定義する場合、ファイルが大きすぎるとダウンロードが失敗し、ファイルが破損します。 、エラーは報告されません;
2. 理由:
これは、readfile がファイルを読み取るときにファイルがキャッシュに入れられ、メモリ オーバーフローが発生するためです。 ##3. 解決策: 分割してダウンロードし、ダウンロード速度を制限する;
<?php //设置文件最长执行时间 set_time_limit(0); if (isset($_GET['filename']) && !empty($_GET['filename'])) { $file_name = $_GET['filename']; $file = __DIR__ . '/assets/' . $file_name; } else { echo 'what are your searching for?'; exit(); } if (file_exists($file) && is_file($file)) { $filesize = filesize($file); header('Content-Description: File Transfer'); header('Content-Type: application/octet-stream'); header('Content-Transfer-Encoding: binary'); header('Accept-Ranges: bytes'); header('Expires: 0'); header('Cache-Control: must-revalidate'); header('Pragma: public'); header('Content-Length: ' . $filesize); header('Content-Disposition: attachment; filename=' . $file_name); // 打开文件 $fp = fopen($file, 'rb'); // 设置指针位置 fseek($fp, 0); // 开启缓冲区 ob_start(); // 分段读取文件 while (!feof($fp)) { $chunk_size = 1024 * 1024 * 2; // 2MB echo fread($fp, $chunk_size); ob_flush(); // 刷新PHP缓冲区到Web服务器 flush(); // 刷新Web服务器缓冲区到浏览器 sleep(1); // 每1秒 下载 2 MB } // 关闭缓冲区 ob_end_clean(); fclose($fp); } else { echo 'file not exists or has been removed!'; } exit();
以上がPHPファイルのダウンロードが失敗する原因の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。