PHPのob_start()関数

Jun 23, 2016 pm 02:31 PM

PHP の ob_start() を使用してブラウザのキャッシュを制御します (再掲)

転載元: http://home.phpchina.com/space.php?uid=52440&do=blog&id=38971

出力制御
この関数を使用すると、自由にスクリプト内のデータの出力を制御します。特にデータ出力後にファイルヘッダーを出力したい場合に非常に便利です。出力制御関数は、header()
または setcookie() を使用して送信されるファイル ヘッダー情報には影響しませんが、echo() や PHP コードと同様のデータ ブロックにのみ影響します。

出力制御の一般的な印象を皆さんに伝えるための簡単な例を見てみましょう:
例 1.

‐‐‐‐‐‐‐ out-off' を


header("location:index .php"); // ブラウザをindex.phpにリダイレクトします
ob_end_flush(); // すべてのコンテンツをブラウザに出力します
?>

この関数がファイルを送信することは誰もが知っていますヘッダーをブラウザーに送信しますが、この関数を使用する前に出力 (スペース、キャリッジ リターン、ライン フィードなどの空の出力を含む) がある場合は、エラーが表示されます。最初の行の ob_start() を削除してこのプログラムを再度実行すると、次のエラー メッセージが表示されることがわかります。「Header

had all Ready send

by」!ただし、ob_start を使用すると、エラー メッセージは表示されません。その理由は、バッファーが開かれたときに、echo 以降の文字がブラウザーに出力されず、flush を使用するまでサーバー上に出力されないためです。または ob_end_flush なので、ファイル ヘッダー出力エラーは発生しません。

1. 関連関数の紹介:

1. フラッシュ: バッファーと出力の内容を更新します。
関数形式: flash()
説明: この関数は頻繁に使用され、非常に効率的です。
2. ob_start: 出力バッファを開きます
関数形式: void ob_start(void)
説明: バッファがアクティブ化されると、PHP プログラムからのファイル以外のヘッダー情報はすべて送信されず、内部バッファに保存されます。バッファの内容を出力するには、ob_end_flush() または flash() を使用してバッファの内容を出力します。
3. ob_get_contents: 内部バッファの内容を返します。
使用法: string ob_get_contents(void)
説明: この関数は、出力バッファがアクティブ化されていない場合、現在のバッファの内容を返します。
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 の意味を知っています。 ob_implicit_flush 関数はそれと同じです。絶対出力をオンにした後、各スクリプト出力はブラウザに直接送信されます。 2. 詳細理解:

1. フラッシュ関数について:
この関数は PHP3 で登場し、ブラウザのキャッシュを更新する非常に便利な関数です。フラッシュを説明するために、非常に明らかな動作効果を持つ例を示します。例 2 .

      CODE for($i = 1; $i <= 300; $i++ ) print(" ");
// 这一句话非常关键,cache的结构使得它的内容只有达到一定的大小才能从浏览器里输出
// 换言之,如果cache的内容不达到一定的大小,它是不会在程序执行完毕前输出的。经
// 过测试,我发现这个大小的底限是256个字符长。这意味着cache以后接收的内容都会
// 源源不断的被发送出去。
For($j = 1; $j <= 20; $j++) {
echo $j."
";
flush(); //这一部会使cache新增的内容被挤出去,显示到浏览器上
sleep(1); //让程序"睡"一秒钟,会让你把效果看得更清楚
}
?>


      具体效果你可以到这里看看[url]http://www.php2000.com/~uchinaboy/out.php[/url]
      PHP2000的最新的PHP聊天室就是用的这个技术,可惜的是源代码未公开 L
      注:如果在程序的首部加入ob_implicit_flush()打开绝对刷新,就可以在程序中不再使用flush(),这样做的好处是:提高效率!

      2. 关于ob系列函数:
      我想先引用我的好朋友y10k的一个例子:
      Example 3.

      比如你用得到服务器和客户端的设置信息,但是这个信息会因为客户端的不同而不同,如果想要保存phpinfo()函数的输出怎么办呢?在没有缓冲区控制之前,可以说一点办法也没有,但是有了缓冲区的控制,我们可以轻松的解决:
      CODE ob_start(); //打开缓冲区
phpinfo(); //使用phpinfo函数
$info=ob_get_contents(); //得到缓冲区的内容并且赋值给$info
$file=fopen(\'info.txt\',\'w\'); //打开文件info.txt
fwrite($file,$info); //写入信息到info.txt
fclose($file); //关闭文件info.txt
?>


      用以上的方法,就可以把不同用户的phpinfo信息保存下来,这在以前恐怕没有办法办到!其实上面就是将一些"过程"转化为"函数"的方法!
      或许有人会问:"难道就这个样子吗?还有没有其他用途?"当然有了,比如笔者论坛的PHP 
      语法加亮显示就和这个有关(PHP默认的语法加亮显示函数会直接输出,不能保存结果,如果在每次调用都显示恐怕会很浪费CPU,笔者的论坛就把语法加亮函数显示的结果用控制缓冲区的方法保留了),大家如果感兴趣的话可以来看看[url]http://www.zphp.com/bbs/[/url]!

      可能现在大家对ob_start()的功能有了一定的了解,上面的一个例子看似简单,但实际上已经掌握了使用ob_start()的要点。
      <1>.使用ob_start打开browser的cache,这样可以保证cache的内容在你调用flush(),ob_end_flush()(或程序执行完毕)之前不会被输出。
      <2>.现在的你应该知道你所拥有的优势:可以在任何输出内容后面使用header,setcookie以及session,这是ob_start一个很大的特点;也可以使用ob_start的参数,在cache被写入后,然后自动运行命令,比如ob_start(\"ob_gzhandler\");而我们最常用的做法是用ob_get_contents()得到cache中的内容,然后再进行处理……
      <3>.当处理完毕后,我们可以使用各种方法输出,flush(),ob_end_flush(),以及等到程序执行完毕后的自动输出。当然,如果你用的是ob_get_contents(),那么就要你自己控制输出方式了。

      来,让我们看看能用ob系列函数做些什么……

      一、 静态模版技术

はじめに: いわゆる静的テンプレート技術は、特定の方法を使用して、ユーザーがクライアント側の PHP によって生成された HTML ページを取得できるようにします。この HTML ページが更新されなくなると、別のユーザーがこのページを再度参照したときに、プログラムは、sina、163、sohu などの大量の情報を含む一部の Web サイトの PHP および関連データベースを呼び出すことはなくなります。このようなテクノロジーの恩恵は非常に大きいです。

私が知っている静的出力を実現するには 2 つの方法があります:
<1> y10k によって修正された phplib の template.inc.php というクラスを通じて実装されます。 2 < 2 & gt ; OBシリーズの機能を使用して実装します。
最初の方法については、この記事で検討する問題ではないため、詳細は説明しません。 ️ 2 番目のメソッドの具体的な実装を見てみましょう - 例 4.
$content = ob_get_contents();// 次のように出力されるすべてのコンテンツを取得しますPHP ページ
$fp = fopen("output00001.html", "w "); // $ fp = fp、$ content); // phpページのすべてのコンテンツをoutput00001.htmlに書き込み、そして...


2.キャプチャ出力

上記の例4.最も単純なケースです。書き込む前に $content を操作することもできます。
いくつかのキーワードを取得してから、例 3 で説明されている PHP 構文の強調表示などの処理を実行することもできます。個人的には、この機能がさまざまな問題を解決できる一番の部分だと思いますが、十分な想像力が必要です...
例 5.
‐ off ‐ ‐ ‐ ‐ ‐‐‐ ‐
If($code) {
ob_start(); exit();
$contents を返します...

例 6送信を高速化します


CODE<?
/*
** Title.........: PHP4 HTTP Compression Speeds up the Web
** Version.......: 1.20
** Author........: catoc <[email]catoc@163.net[/email]>
      ** Filename......: gzdoc.php
      ** Last changed..: 18/10/2000
      ** Requirments...: PHP4 >= 4.0.1
      ** PHP was configured with --with-zlib[=DIR]
      ** Notes.........: Dynamic Content Acceleration compresses
      ** the data transmission data on the fly
      ** code by sun jin hu (catoc) <[email]catoc@163.net[/email]>
      ** Most newer browsers since 1998/1999 have
      ** been equipped to support the HTTP 1.1
      ** standard known as \"content-encoding.\"
      ** Essentially the browser indicates to the
      ** server that it can accept \"content encoding\"
      ** and if the server is capable it will then
      ** compress the data and transmit it. The
      ** browser decompresses it and then renders
      ** the page.
      **
      ** Modified by John Lim ([email]jlim@natsoft.com.my[/email])
      ** based on ideas by Sandy McArthur, Jr
      ** Usage........:
      ** No space before the beginning of the first \' ** ------------Start of file----------
** |<?
** | include(\'gzdoc.php\');
** |? >
      ** |
      ** |... the page ...
      ** |
      ** | ** | gzdocout();
** |? >
      ** -------------End of file-----------
      */
      ob_start();
      ob_implicit_flush(0);
      function CheckCanGzip(){
      global $HTTP_ACCEPT_ENCODING;
      if (headers_sent() || connection_timeout() || connection_aborted()){
      return 0;
      }
      if (strpos($HTTP_ACCEPT_ENCODING, \'x-gzip\') !== false) return 
\"x-gzip\";
      if (strpos($HTTP_ACCEPT_ENCODING,\'gzip\') !== false) return \"gzip\";
      return 0;
      }
      /* $level = compression level 0-9, 0=none, 9=max */
      function GzDocOut($level=1,$debug=0){
      $ENCODING = CheckCanGzip();
      if ($ENCODING){
      print \"nn\";
      $Contents = ob_get_contents();
      ob_end_clean();
      if ($debug){
      $s = \"

Not compress length: \".strlen($Contents);
      $s .= \"
      Compressed length: \".strlen(gzcompress($Contents,$level));
      $Contents .= $s;
      }
      header(\"Content-Encoding: $ENCODING\");
      print \"x1fx8bx08x00x00x00x00x00\";
      $Size = strlen($Contents);
      $Crc = crc32($Contents);
      $Contents = gzcompress($Contents,$level);
      $Contents = substr($Contents, 0, strlen($Contents) - 4);
      print $Contents;
      print pack(\'V\',$Crc);
      print pack(\'V\',$Size);
      exit;
      }else{
      ob_end_flush();
      exit;
      }
      }
      ?>

      这是catoc的一段很早以前的代码,是在weblogs.com看到的,他利用了zlib的函数,对传输的内容进行了压缩,测试表明,对于10k以上的页面,会产生效果,而且页面越大,效果越明显……

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

11ベストPHP URLショートナースクリプト(無料およびプレミアム) 11ベストPHP URLショートナースクリプト(無料およびプレミアム) Mar 03, 2025 am 10:49 AM

多くの場合、キーワードと追跡パラメーターで散らかった長いURLは、訪問者を阻止できます。 URL短縮スクリプトはソリューションを提供し、ソーシャルメディアやその他のプラットフォームに最適な簡潔なリンクを作成します。 これらのスクリプトは、個々のWebサイトにとって価値があります

Instagram APIの紹介 Instagram APIの紹介 Mar 02, 2025 am 09:32 AM

2012年のFacebookによる有名な買収に続いて、Instagramはサードパーティの使用のために2セットのAPIを採用しました。これらはInstagramグラフAPIとInstagram Basic Display APIです。

Laravelでフラッシュセッションデータを使用します Laravelでフラッシュセッションデータを使用します Mar 12, 2025 pm 05:08 PM

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

LaravelのバックエンドでReactアプリを構築する:パート2、React LaravelのバックエンドでReactアプリを構築する:パート2、React Mar 04, 2025 am 09:33 AM

これは、LaravelバックエンドとのReactアプリケーションの構築に関するシリーズの2番目と最終部分です。シリーズの最初の部分では、基本的な製品上場アプリケーションのためにLaravelを使用してRESTFUL APIを作成しました。このチュートリアルでは、開発者になります

Laravelテストでの簡略化されたHTTP応答のモッキング Laravelテストでの簡略化されたHTTP応答のモッキング Mar 12, 2025 pm 05:09 PM

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

PHPのカール:REST APIでPHPカール拡張機能を使用する方法 PHPのカール:REST APIでPHPカール拡張機能を使用する方法 Mar 14, 2025 am 11:42 AM

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Codecanyonで12の最高のPHPチャットスクリプト Codecanyonで12の最高のPHPチャットスクリプト Mar 13, 2025 pm 12:08 PM

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

2025 PHP状況調査の発表 2025 PHP状況調査の発表 Mar 03, 2025 pm 04:20 PM

2025 PHP Landscape Surveyは、現在のPHP開発動向を調査しています。 開発者や企業に洞察を提供することを目的とした、フレームワークの使用、展開方法、および課題を調査します。 この調査では、現代のPHP Versioの成長が予想されています

See all articles