ホームページ >バックエンド開発 >PHPチュートリアル >PHP_PHP チュートリアルのバッファー制御のコード
PHP を使用するとき、誰もが必然的に header 関数と setcookie 関数を使用します。これら 2 つの関数はファイルのヘッダー情報をブラウザーに送信しますが、これら 2 つの関数を使用する前に何らかの出力 (スペースなどの空の出力を含む) がある場合は、キャリッジ リターンとライン フィード) を使用するとエラーが表示され、プロンプト情報は次のとおりです。「ヘッダーの送信準備がすべて整いました」!では、出力後にファイルのヘッダー情報を送信する方法はあるのでしょうか? PHP 4.0 にはバッファ制御のための関数がいくつか追加されています。これらの関数を使用すると、多くの問題を解決できます。
1. 関連機能の紹介:
1. フラッシュ: バッファー内の内容を出力し、バッファーを削除します。
関数形式:flush()
注: この機能は頻繁に使用され、非常に効率的です。
2. ob_start: 出力バッファを開きます
関数形式: void ob_start(void)
注: バッファーがアクティブ化されると、PHP プログラムからのファイル以外のヘッダー情報はすべて送信されず、内部バッファーに保存されます。バッファの内容を出力するには、ob_end_flush() を使用するか、ob_end_clean() を使用してバッファの内容を出力します。
3、ob_get_contents: 内部バッファの内容を返します。
使用法: 文字列 ob_get_contents(void)
説明: この関数は、出力バッファがアクティブ化されていない場合、現在のバッファの内容を返します。FALSE を返します。
4. ob_get_length: 内部バッファーの長さを返します。
使用法: int ob_get_length(void)
説明: この関数は、出力バッファがアクティブ化されていない場合、ob_get_contents と同じように現在のバッファの長さを返します。その後、FALSE を返します。
5. ob_end_flush: 内部バッファの内容をブラウザに送信し、出力バッファを閉じます。
使用法: void ob_end_flush(void)
説明: この関数は、出力バッファーの内容 (存在する場合) を送信します。
6. ob_end_clean: 内部バッファの内容を削除し、内部バッファを閉じます
使用法: void ob_end_clean(void)
注意: この関数は内部バッファの内容を出力しません。
7. ob_implicit_flush: 絶対リフレッシュをオンまたはオフにします
使用法: void ob_implicit_flush ([int flag])
注: Perl を使用したことがある人なら誰でも、?$|=x の意味を知っています。この文字列はバッファを開いたり閉じたりできます。デフォルトでは、バッファを閉じて絶対出力を開きます。
2. 使用例:
冒頭で著者はバッファ制御機能を使うことでファイルヘッダの情報送信エラーを防ぐことができると述べました。
例:
ob_start(); // バッファを開きます
ob_start が削除されると、PHP はファイルの 4 行目でエラーを表示します (エラー メッセージは上記のとおりです)。ただし、ob_start を追加すると、バッファが開かれるときにエラーは表示されません。 echo の後の文字は出力されません。出力はブラウザに送信されますが、サーバーには残ります。flush または ob_end_flush を使用するまで出力されないため、ファイル ヘッダーの出力エラーは発生しません。
以下は非常に古典的な使用法です:
例えば、>
上記の方法を使用すると、さまざまなユーザーの phpinfo 情報を保存できます。これは以前は不可能だったかもしれません。実は上記は一部の「処理」を「関数」に変換する方法なのです!
。