Webエンジニア向けプログラミング解説動画をYouTubeで配信中!
▶ チャンネル登録はこちら

【PHP8.x】CURLINFO_CONTENT_LENGTH_DOWNLOAD定数の使い方

CURLINFO_CONTENT_LENGTH_DOWNLOAD定数の使い方について、初心者にもわかりやすく解説します。

作成日: 更新日:

基本的な使い方

CURLINFO_CONTENT_LENGTH_DOWNLOAD定数は、PHPのcURL拡張機能で使用される、ダウンロードされるコンテンツの予想サイズ(バイト単位)を表す定数です。この定数は、curl_getinfo() 関数と組み合わせて使用することで、HTTPリクエストを通じて取得するコンテンツの総バイト数を把握するために利用されます。

Webサーバーからファイルやデータをダウンロードする際、サーバーは通常、HTTPレスポンスヘッダーに Content-Length というフィールドを含め、これから送信するデータの総サイズをクライアントに通知します。CURLINFO_CONTENT_LENGTH_DOWNLOAD定数を使用すると、この Content-Length ヘッダーの値を取得することが可能です。これにより、例えばダウンロードの進捗状況をユーザーに表示したり、ダウンロードを開始する前に必要なディスク容量を概算したりするのに役立ちます。

ただし、この値はサーバーが通知する「予想サイズ」であり、必ずしも実際にダウンロードされたデータの正確なサイズと一致するとは限りません。例えば、コンテンツが動的に生成される場合や、チャンク転送などの方法でデータが送られる場合、Content-Length ヘッダーが存在しないことがあります。その場合、この定数を使った curl_getinfo() 関数は -1 を返します。そのため、この定数の値を利用する際は、-1 が返される可能性も考慮してプログラムを設計することが重要です。この定数を活用することで、ダウンロード処理の制御をより詳細に行い、ユーザーエクスペリエンスを向上させるための情報として役立てることができます。

構文(syntax)

1curl_getinfo($ch, CURLINFO_CONTENT_LENGTH_DOWNLOAD);

引数(parameters)

引数なし

引数はありません

戻り値(return)

float

この定数は、リクエストされたリソースのダウンロードバイト数を浮動小数点数(float)で返します。

関連コンテンツ