php でバッファを閉じる方法: 1. PHP インストール ディレクトリを開き、設定ファイル「php.ini」を見つけて開きます; 2. 設定ファイル内で「output_buffering」項目を見つけ、この項目の値を「Off」に設定するだけです。
このチュートリアルの動作環境: Windows7 システム、PHP7.1 バージョン、DELL G3 コンピューター
PHP バッファ( バッファ)
スクリプトの出力情報は最初にバッファに入れられ、バッファがいっぱいになるかスクリプトの実行が終了した場合にのみ、データが次のステージに転送されます。設定ファイル php.ini に output_buffering
設定項目があります。私のデフォルト設定 (Windows/XAMPP v3.2.2) は 4096
If On に設定すると、バッファは使用可能でサイズ制限はありません。
Off に設定すると、バッファは使用できなくなります。
#設定した場合整数にバッファを指定します 領域は利用可能であり、設定されたサイズです (バイト単位)
ini_set ではバッファ サイズを設定できないことに注意してください。スクリプト実行環境の初期化時に、バッファは定義されています。 cli モードでは、デフォルトの Output_buffering は Off です。
それでは、バッファを閉じることと開くことの違いは何でしょうか?初期バッファサイズは何をするのでしょうか? cli モードはデフォルトでオフになっていますが、ビジネスで必要な場合にオンにすることはできますか?キャッシュ領域の利点は何ですか?
1. バッファを閉じることと開くことの違いは何ですか?
パスコード検査
output_buffering が 4096 に設定されている場合、コードを実行します
出力結果: 3 を待った後秒、出力の開始と終了は同時に行われます。
Output_buffering が Off に設定されている場合、同じコードを実行します。
出力結果: start が最初に出力され、3 秒待った後に end が出力されます。
## が出力されます #これだけ見ると結果は全く同じですね~ しかし、その動作過程を観察してみると、意外な違いが分かりました。バッファリングがオフの場合は、最初に「start」が出力され、次に 3 秒待ってから「end」が出力されます。バッファーがオンになると、スクリプトの実行が完了するまで待機し、結果をまとめて出力します。 この例では、PHP バッファーが直接接続を確立できるようにするのと同様に、フラッシュを使用して Apache バッファーをリフレッシュします。ブラウザとの接続により、PHP バッファ自体に注意を集中できるようになります。 わかりやすい例で説明すると、PHP のバッファは大きな家のようなもので、echo などの出力関数が実行されるたびに、スクリプトの実行が完了するか ob_flush 関数が実行されるまで、データがこの大きな家の中に放り込まれます。 . データは大きな家から解放され、WebServer のバッファにスローされます。 PHP バッファを閉じた後、echo 関数が実行されますが、それを置く大きな家がない場合はどうすればよいでしょうか? WebServer バッファに直接渡す必要があります。 例とコードの実行結果を通じて、いわゆる PHP バッファーは PHP 自体によって開発されたデータ ストレージ ハブであり、一連の ob 関数がこの目的のために動作することがわかります。 (関数の例をいくつか挙げます) ob_clean(); // 内部バッファの内容を削除します。バッファは閉じません (出力なし)。 ob_end_clean(); //内部バッファの内容を削除し、バッファを閉じます(出力なし)。 ob_get_contents(); //バッファの内容を返します。出力はしません ob_get_length(); //内部バッファの長さを返します。バッファがアクティブ化されていない場合、これは関数は FALSE を返します。2. 初期バッファ サイズの役割は何ですか?
テストの実行を容易にするために、output_buffering を 4096 から 5 に変更します実行コード3. cli モードはデフォルトでオフになっていますが、ビジネスで必要な場合にオンにすることはできますか?
この質問は補足できます。非 cli モードで、php.ini がバッファを閉じるように設定しているのに、ビジネスでバッファを使用する必要がある場合、どうすればよいですか?構成を変更しますか?もちろん、それほど難しいことではありません。このとき、別の ob 関数が来ます, ob_start(); //出力バッファを開きます。すべての出力情報はブラウザに直接送信されるのではなく、保存されます。出力バッファ内。 PHP バッファーが一時データ保存領域の概念に似ていることがわかったので、TP5 ソース コードに戻って見てみましょう。まず、ob_get_level 関数と ob_get_clean 関数の説明を見てみましょう。
ob_get_level(): 出力バッファリング メカニズムのネスト レベルを返します。
ob_get_clean(): 現在のバッファの内容を取得し、現在の出力バッファを削除します。
コードから 1 つまたは 2 つのことを学ぶこともできます。レベルが 0 より大きい場合は、バッファーの内容を取得してバッファーを削除し、ob_start を通じて新しいバッファーを開きます。これもコメントの指示に従っています。「再適用」。
ここではいわゆるネスティングについて説明しますが、level の値がいつ 0 になるのか、0 以外の場合はどうなるのかについては、php.ini の Output_buffering をオフにして出力して結果を確認してください。 。さらに、ob_startを複数回、ob_get_levelを複数回実行して、出力結果を比較してみます。
最初に 2 つのモデルを見てみましょう
4. キャッシュ領域の利点は何ですか?
PHP の出力データは WebServer に送信されますが、echo を一度実行して送信するとリソースの消費が大きくなりますので、メモリに格納して一律に送信した方が効率的です。 Web リクエストには HTTP ヘッダーが含まれており、ヘッダーが設定される前に出力があってはなりません。 PHP バッファはこの作業を行い、ヘッダーを送信する前にさまざまなデータを出力し、最初にヘッダー情報を WebSever に送信し、次にデータ パケットを均一に送信します。 推奨学習: 「PHP ビデオ チュートリアル 」
以上がPHPでバッファを閉じる方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、酸とベースのデータベースモデルを比較し、その特性と適切なユースケースを詳述しています。酸は、財務およびeコマースアプリケーションに適したデータの整合性と一貫性を優先し、ベースは可用性に焦点を当て、

この記事では、コードインジェクションのような脆弱性を防ぐために、PHPファイルのアップロードを確保することについて説明します。ファイルタイプの検証、セキュアストレージ、およびアプリケーションセキュリティを強化するエラー処理に焦点を当てています。

記事では、組み込み関数、ホワイトリストアプローチ、サーバー側の検証などの手法に焦点を当てたセキュリティを強化するためのPHP入力検証のベストプラクティスについて説明します。

この記事では、Token BucketやLeaky BucketなどのアルゴリズムやSymfony/Rate-Limiterなどのライブラリを使用するなど、PHPでAPIレート制限を実装するための戦略について説明します。また、監視、動的に調整されたレートの制限、および手をカバーします

この記事では、パスワードを保護するためにPHPでpassword_hashとpassword_verifyを使用することの利点について説明します。主な議論は、これらの関数が自動塩の生成、強力なハッシュアルゴリズム、およびSecurを通じてパスワード保護を強化するということです

この記事では、PHPおよび緩和戦略におけるOWASPトップ10の脆弱性について説明します。重要な問題には、PHPアプリケーションを監視および保護するための推奨ツールを備えたインジェクション、認証の壊れ、XSSが含まれます。

この記事では、PHPでのXSS攻撃を防ぐための戦略について説明し、入力の消毒、出力エンコード、セキュリティを向上させるライブラリとフレームワークの使用に焦点を当てています。

この記事では、PHPでのインターフェイスと抽象クラスの使用について説明し、それぞれをいつ使用するかに焦点を当てています。インターフェイスは、無関係なクラスや複数の継承に適した、実装なしで契約を定義します。抽象クラスは共通の機能を提供します


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SublimeText3 中国語版
中国語版、とても使いやすい

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、
