ホームページ >バックエンド開発 >PHPチュートリアル >正しい HTTP ヘッダーを設定すると、PHP でのダウンロード エクスペリエンスがどのように向上しますか?

正しい HTTP ヘッダーを設定すると、PHP でのダウンロード エクスペリエンスがどのように向上しますか?

DDD
DDDオリジナル
2024-11-20 01:18:02665ブラウズ

How does setting the correct HTTP headers enhance the download experience in PHP?

ファイル ダウンロードの HTTP 応答ヘッダー

PHP でファイルのダウンロードを処理する場合、ブラウザーに指示する適切な HTTP ヘッダーを設定することが重要です。ブラウザにファイルを表示するのではなく、ダウンロードを開始します。考慮すべき重要なヘッダーの 1 つは、「Content-Type」です。

「Content-Type」の重要性

「Content-Type」ヘッダーの設定は重要です。場合によっては、ファイル タイプの識別が間違っていると一部のユーザーから報告されています。 「Content-Type」を指定しないと、ブラウザがデフォルトの想定に頼って、不適切なファイル処理につながる可能性があります。

汎用ファイル タイプ

さまざまなファイル拡張子に MIME タイプをハードコードするのに対し、より汎用性の高い解決策は、既知の MIME タイプの配列を使用して、ファイル拡張子に基づいて MIME タイプを動的に決定することです。このアプローチにより、プロセスが簡素化され、大規模なハードコーディングの必要性が回避されます。

パフォーマンスの最適化

提供されたコード スニペットで直面しているパフォーマンスの問題に対処するには、ファイルを検査する価値があります。ファイルの読み取りに使用されるサイズとチャンク サイズ。ファイル サイズが大きく、チャンク サイズが比較的小さい場合、ブラウザのダウンロード ダイアログの表示に顕著な遅延が発生する可能性があります。パフォーマンスを向上させるために、より大きなチャンク サイズを使用することを検討してください。

更新されたコード

これは、前述の問題に対処した、提供されたコードの最適化されたバージョンです。

/**
 * Outputs the specified file to the browser.
 *
 * @param string $filePath the path to the file to output
 * @param string $fileName the name of the file
 * @param string $mimeType the type of file
 */
function outputFile($filePath, $fileName, $mimeType = '') {
    // Setup
    $mimeTypes = array(
        'pdf' => 'application/pdf',
        'txt' => 'text/plain',
        'html' => 'text/html',
        'exe' => 'application/octet-stream',
        'zip' => 'application/zip',
        'doc' => 'application/msword',
        'xls' => 'application/vnd.ms-excel',
        'ppt' => 'application/vnd.ms-powerpoint',
        'gif' => 'image/gif',
        'png' => 'image/png',
        'jpeg' => 'image/jpg',
        'jpg' => 'image/jpg',
        'php' => 'text/plain'
    );

    $fileSize = filesize($filePath);
    $fileName = rawurldecode($fileName);
    $fileExt = '';

    // Determine MIME Type
    if($mimeType == '') {
        $fileExt = strtolower(substr(strrchr($filePath, '.'), 1));

        if(array_key_exists($fileExt, $mimeTypes)) {
            $mimeType = $mimeTypes[$fileExt];
        }
        else {
            $mimeType = 'application/force-download';
        }
    }

    // Disable Output Buffering
    @ob_end_clean();

    // IE Required
    if(ini_get('zlib.output_compression')) {
        ini_set('zlib.output_compression', 'Off');
    }

    // Send Headers
    header('Content-Type: ' . $mimeType);
    header('Content-Disposition: attachment; filename="' . $fileName . '"');
    header('Content-Transfer-Encoding: binary');
    header('Accept-Ranges: bytes');

    // Send Headers: Prevent Caching of File
    header('Cache-Control: private');
    header('Pragma: private');
    header('Expires: Mon, 26 Jul 1997 05:00:00 GMT');

    // Multipart-Download and Download Resuming Support
    if(isset($_SERVER['HTTP_RANGE'])) {
        list($a, $range) = explode('=', $_SERVER['HTTP_RANGE'], 2);
        list($range) = explode(',', $range, 2);
        list($range, $rangeEnd) = explode('-', $range);

        $range = intval($range);

        if(!$rangeEnd) {
            $rangeEnd = $fileSize - 1;
        }
        else {
            $rangeEnd = intval($rangeEnd);
        }

        $newLength = $rangeEnd - $range + 1;

        // Send Headers
        header('HTTP/1.1 206 Partial Content');
        header('Content-Length: ' . $newLength);
        header('Content-Range: bytes ' . $range - $rangeEnd / $fileSize);
    }
    else {
        $newLength = $fileSize;
        header('Content-Length: ' . $fileSize);
    }

    // Output File
    $chunkSize = 8 * (1024*1024);
    $bytesSend = 0;

    if($file = fopen($filePath, 'r')) {
        if(isset($_SERVER['HTTP_RANGE'])) {
            fseek($file, $range);

            while(!feof($file) && !connection_aborted() && $bytesSend < $newLength) {
                $buffer = fread($file, $chunkSize);
                echo $buffer;
                flush();
                $bytesSend += strlen($buffer);
            }
            
            fclose($file);
        }
    }
}

結論

適切な「Content-Type」を設定し、ファイルの読み取りと出力を最適化することで、この更新されたコードは、PHP スクリプトによって処理されるファイル ダウンロードのパフォーマンスと信頼性を向上させるはずです。 .

以上が正しい HTTP ヘッダーを設定すると、PHP でのダウンロード エクスペリエンスがどのように向上しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。