Heim  >  Artikel  >  Backend-Entwicklung  >  Detaillierte Erläuterung des Beispiels für die PHP-Ausgabe-Cache-Funktion

Detaillierte Erläuterung des Beispiels für die PHP-Ausgabe-Cache-Funktion

伊谢尔伦
伊谢尔伦Original
2017-06-24 13:50:541277Durchsuche

Mit der Ausgabesteuerungsfunktion können Sie die Ausgabe von Daten im Skript frei steuern. Dies ist sehr nützlich, insbesondere wenn Sie den Dateiheader nach der Datenausgabe ausgeben möchten.

Die Ausgabesteuerungsfunktion hat keinen Einfluss auf die mit header() oder setcookie() gesendeten Datei-Header-Informationen, sondern nur auf die Datenblöcke, die echo() und PHP-Code ähneln.
Lassen Sie uns zunächst ein einfaches Beispiel geben, um jedem einen allgemeinen Eindruck von der Ausgabesteuerung zu vermitteln:
Beispiel 1.

<?php 
ob_start(); //打开缓冲区 
echo \"Hellon\"; //输出 
header(“location:index.php”); //把浏览器重定向到index.php 
ob_end_flush
();//输出全部内容到浏览器 
?>

Jeder, der die Funktion header() kennt Wie wir alle wissen, Diese Funktion sendet einen Dateiheader an den Browser. Wenn jedoch vor der Verwendung dieser Funktion eine Ausgabe erfolgt (einschließlich leerer Ausgaben wie Leerzeichen, Wagenrückläufe und Zeilenvorschübe), wird ein Fehler angezeigt. Wenn wir ob_start() in der ersten Zeile entfernen und dann dieses Programm ausführen, erhalten wir eine Fehlermeldung: „Header had all ready send by“! Bei ob_start erfolgt jedoch keine Fehlermeldung. Der Grund dafür ist, dass die Zeichen nach dem Echo nicht an den Browser ausgegeben werden, sondern auf dem Server erhalten bleiben. Sie werden erst ausgegeben, wenn Sie Flush verwenden oder ob_end_flush, damit keine Datei-Header-Ausgabefehler auftreten!
1. Einführung in verwandte Funktionen:
1.
Funktionsformat: Flush()
Beschreibung: Diese Funktion wird häufig verwendet und ist sehr effizient.
2. ob_start: Öffnen Sie den Ausgabepuffer
Funktionsformat: void ob_start(void)
Beschreibung: Wenn der Puffer aktiviert ist, werden alle Nicht-Datei-Header-Informationen aus dem PHP-Programm angezeigt wird nicht gesendet, sondern im internen Puffer gespeichert. Um den Inhalt des Puffers auszugeben, können Sie ob_end_flush() oder Flush() verwenden, um den Inhalt des Puffers auszugeben.
3, ob_get_contents: Gibt den Inhalt des internen Puffers zurück.
Verwendung: string ob_get_contents(void)
Beschreibung: Diese Funktion gibt den Inhalt des aktuellen Puffers zurück. Wenn der Ausgabepuffer nicht aktiviert ist, wird FALSE zurückgegeben.
4. ob_get_length: Gibt die Länge des internen Puffers zurück.
Verwendung: int ob_get_length(void)
Beschreibung: Diese Funktion gibt die Länge im aktuellen Puffer zurück, genau wie ob_get_contents, wenn der Ausgabepuffer nicht aktiviert ist. gibt dann FALSE zurück.
5. ob_end_flush: Senden Sie den Inhalt des internen Puffers an den Browser und schließen Sie den Ausgabepuffer.
Verwendung: void ob_end_flush(void)
Beschreibung: Diese Funktion sendet den Inhalt des Ausgabepuffers (falls vorhanden).
6. ob_end_clean: Löschen Sie den Inhalt des internen Puffers und schließen Sie den internen Puffer
Verwendung: void ob_end_clean(void)
Erklärung: Diese Funktion funktioniert nicht Gibt den Inhalt des internen Puffers aus, löscht ihn aber!
7. ob_implicit_flush: Absolute Aktualisierung ein- oder ausschalten
Verwendung: void ob_implicit_flush ([int flag])
Hinweis: Jeder, der Perl verwendet hat, weiß das Die Bedeutung von $|=x, diese Zeichenfolge kann den Puffer öffnen/schließen, und die Funktion ob_implicit_flush ist die gleiche. Nach dem Einschalten der absoluten Ausgabe wird jede Skriptausgabe direkt an den Browser gesendet , wird nicht mehr benötigt. Rufen Sie „flush()“ auf Eine nützliche Funktion zum Aktualisieren des Browser-Cache.
Beispiel 2.
Der neueste PHP-Chatroom von PHP2000 verwendet diese Technologie . Leider wurde der Quellcode noch nicht veröffentlicht.
Hinweis: Wenn Sie ob_implicit_flush() am Anfang des Programms hinzufügen, können Sie „flush()“ nicht mehr im Programm verwenden Der Vorteil davon ist: verbesserte Effizienz!

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

Beispiel 3.
Zum Beispiel können Sie die Einstellungsinformationen des Servers und des Clients verwenden, diese Informationen sind jedoch aufgrund von Unterschieden unterschiedlich Clients: Was soll ich tun, um die Ausgabe der Funktion phpinfo() zu speichern? Bevor es keine Pufferkontrolle gab, kann man sagen, dass es überhaupt keine Möglichkeit gab, aber mit der Pufferkontrolle können wir es leicht lösen:

<?php 
ob_start(); //打开缓冲区 
phpinfo(); //使用phpinfo函数 
$info=ob_get_contents(); //得到缓冲区的内容并且赋值给$info 
$file=fopen(\&#39;info.txt\&#39;,\&#39;w\&#39;); //打开文件info.txt 
fwrite($file,$info); //写入信息到info.txt 
fclose($file); //关闭文件info.txt 
?>

用以上的方法,就可以把不同用户的phpinfo信息保存下来,这在以前恐怕没有办法办到!其实上面就是将一些“过程”转化为“函数”的方法!
或许有人会问:“难道就这个样子吗?还有没有其他用途?”当然有了,比如笔者论坛的PHP 语法加亮显示就和这个有关(PHP默认的语法加亮显示函数会直接输出,不能保存结果,如果在每次调用都显示恐怕会很浪费CPU,笔者的论坛就把语法加亮函数显示的结果用控制缓冲区的方法保留了),大家如果感兴趣的话可以来看看http://www.zphp.com/bbs/!
可能现在大家对ob_start()的功能有了一定的了解,上面的一个例子看似简单,但实际上已经掌握了使用ob_start()的要点。
f35d6e602fd7d0f0edfa6f7d103c1b57.使用ob_start打开browser的cache,这样可以保证cache的内容在你调用flush(),ob_end_flush()(或程序执行完毕)之前不会被输出。
2cc198a1d5eb0d3eb508d858c9f5cbdb.现在的你应该知道你所拥有的优势:可以在任何输出内容后面使用header,setcookie以及session,这是 ob_start一个很大的特点;也可以使用ob_start的参数,在cache被写入后,然后自动运行命令,比如 ob_start(\"ob_gzhandler\");而我们最常用的做法是用ob_get_contents()得到cache中的内容,然后再进行处理……
5bdf4c78156c7953567bb5a0aef2fc53.当处理完毕后,我们可以使用各种方法输出,flush(),ob_end_flush(),以及等到程序执行完毕后的自动输出。当然,如果你用的是ob_get_contents(),那么就要你自己控制输出方式了。
来,让我们看看能用ob系列函数做些什么……
一、 静态模版技术
简介:所谓静态模版技术就是通过某种方式,使得用户在client端得到的是由PHP产生的html页面。如果这个html页面不会再被更新,那么当另外的用户再次浏览此页面时,程序将不会再调用PHP以及相关的数据库,对于某些信息量比较大的网站,例如sina,163,sohu。类似这种的技术带来的好处是非常巨大的。
我所知道的实现静态输出的有两种办法:
f35d6e602fd7d0f0edfa6f7d103c1b57.通过y10k修改的phplib的一个叫template.inc.php类实现。
2cc198a1d5eb0d3eb508d858c9f5cbdb.使用ob系列函数实现。
对于第一种方法,因为不是这篇文章所要研究的问题,所以不再赘述。
我们现在来看一看第二种方法的具体实现:
Example 4.

<?php 
ob_start();//打开缓冲区 
?>

php页面的全部输出

<? 
$content = ob_get_contents();//取得php页面输出的全部内容 
$fp = fopen(“output00001.html”, “w”); //创建一个文件,并打开,准备写入 
fwrite($fp, $content); //把php页面的内容全部写入output00001.html,然后…… 
fclose($fp); 
?>

这样,所谓的静态模版就很容易的被实现了……
二、 捕捉输出
以上的Example 4.是一种最简单的情况,你还可以在写入前对$content进行操作……
你可以设法捕捉一些关键字,然后去对它进行再处理,比如Example 3.所述的PHP语法高亮显示。个人认为,这个功能是此函数最大的精华所在,它可以解决各种各样的问题,但需要你有足够的想象力……
Example 5.

<? 
Function run_code($code) { 
If($code) { 
ob_start(); 
eval($code); 
$contents = ob_get_contents(); 
ob_end_clean(); 
}else { 
echo “错误!没有输出”; 
exit(); 
} 
return $contents; 
}

以上这个例子的用途不是很大,不过很典型$code的本身就是一个含有变量的输出页面,而这个例子用eval把$code中的变量替换,然后对输出结果再进行输出捕捉,再一次的进行处理……
Example 6. 加快传输

<?php 
/* 
** Title.........: PHP4 HTTP Compression Speeds up the Web 
** Version.......: 1.20 
** Author........: catoc <catoc@163.net> 
** 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) <catoc@163.net> 
** 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 (jlim@natsoft.com.my) 
** based on ideas by Sandy McArthur, Jr 
** Usage........: 
** No space before the beginning of the first \&#39;<?\&#39; tag. 
** ------------Start of file---------- 
** |<? 
** | include(\&#39;gzdoc.php\&#39;); 
** |? > 
** |<HTML> 
** |... the page ... 
** |</HTML> 
** |<? 
** | 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, \&#39;x-gzip\&#39;) !== false) return \"x-gzip\"; 
if (strpos($HTTP_ACCEPT_ENCODING,\&#39;gzip\&#39;) !== 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 \"n<!-- Use compress $ENCODING -->n\"; 
$Contents = ob_get_contents(); 
ob_end_clean(); 
if ($debug){ 
$s = \"<p>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(\&#39;V\&#39;,$Crc); 
print pack(\&#39;V\&#39;,$Size); 
exit; 
}else{ 
ob_end_flush(); 
exit; 
} 
} 
?>

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

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung des Beispiels für die PHP-Ausgabe-Cache-Funktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn