Maison > Article > développement back-end > Explication détaillée de l'utilisation du cache de sortie des fonctions de la série ob
ob, tampon de sortie, est l'abréviation de mise en mémoire tampon de sortie, pas de cache de sortie. Si ob est utilisé correctement, cela améliorera la vitesse dans une certaine mesure, mais ajouter aveuglément la fonction ob ne fera qu'augmenter la charge supplémentaire sur le processeur
Le principe de base d'ob : si le cache ob est activé , les données d'écho seront envoyées en premier. Mettez-les dans le cache ob. S'il s'agit d'informations d'en-tête, elles sont placées directement dans le cache du programme. Lorsque la page est exécutée jusqu'à la fin, les données ob mises en cache seront placées dans le cache du programme, puis renvoyées à leur tour au navigateur.
Parlons des fonctions de base d'ob :
1) Empêcher l'utilisation de fonctions telles que setcookie(), header() ou session_start() pour envoyer des fichiers d'en-tête après la sortie du navigateur erreur. En fait, il vaut mieux recourir moins souvent à ce genre d’usage et développer de bonnes habitudes de codage.
2) Capturez la sortie de certaines fonctions impossibles à obtenir. Par exemple, phpinfo() produira beaucoup de HTML, mais nous ne pouvons pas utiliser une variable telle que $info=phpinfo(); sera utile.
3) Traitez le contenu de sortie, tel que la compression gzip, la conversion entre le chinois simplifié et le chinois traditionnel et le remplacement de certaines chaînes.
4) Générer des fichiers statiques consiste en fait à capturer la sortie de la page entière, puis à l'enregistrer sous forme de fichier. Souvent utilisé dans la génération HTML ou la mise en cache d'une page entière.
Concernant la compression GZIP évoquée dans le troisième point que nous venons de mentionner, de nombreuses personnes voudront peut-être l'utiliser, mais ne l'ont pas réellement utilisée. En fait, en modifiant légèrement le code, vous pouvez obtenir une compression gzip de la page. .
ob_start(ob_gzhandler); 要缓存的内容
Oui, ajoutez simplement une fonction de rappel ob_gzhandler, mais cela pose quelques problèmes mineurs. Premièrement, cela nécessite la prise en charge de zlib, et deuxièmement, cela ne détermine pas si le navigateur prend en charge gzip (. il semble que maintenant) Ils sont tous pris en charge et les navigateurs iPhone semblent tous les prendre en charge).
L'approche précédente consistait à déterminer si le navigateur prend en charge gzip, puis à utiliser la fonction gzip tierce pour compresser le contenu de ob_get_contents(), et enfin echo.
1. Collection de fonctions couramment utilisées dans la série de fonctions ob
ob_start();
ob_clean(); //Supprime le contenu du tampon interne sans fermer le tampon (pas de sortie).
ob_end_clean(); //Supprime le contenu du tampon interne et ferme le tampon (pas de sortie).
ob_get_clean(); //Renvoie le contenu du tampon interne et ferme le tampon. Équivaut à l'exécution de ob_get_contents() et ob_end_clean()
ob_flush(); envoie le contenu du tampon et supprime le contenu du tampon sans fermer le tampon.
ob_end_flush(); //Envoie le contenu du tampon interne au navigateur, supprime le contenu du tampon et ferme le tampon.
ob_get_flush(); //Renvoie le contenu du tampon interne, ferme le tampon, puis libère le contenu du tampon. Équivalent à ob_end_flush() et renvoie le contenu du tampon.
flush(); // Affiche le contenu publié par ob_flush et le contenu non présent dans le tampon PHP vers le navigateur ; actualise le contenu du tampon interne et l'affiche.
ob_get_contents(); //Renvoie le contenu du tampon sans sortie.
ob_get_length(); //Renvoie la longueur du tampon interne Si le tampon n'est pas activé, cette fonction renvoie FALSE.
ob_get_level(); //Renvoyer le niveau d'imbrication du mécanisme de mise en mémoire tampon de sortie.
ob_get_status(); //Obtenir l'état des tampons de sortie. //Activer ou désactiver l'actualisation absolue. sur ob_implicit_flush(true), ce qu'on appelle l'actualisation absolue signifie que lorsqu'une instruction de sortie (par exemple : echo) est exécutée, la sortie est envoyée directement au navigateur et n'est plus nécessaire. Appelez flush() ou attendez la fin de. le script à afficher.
ob_gzhandler //fonction de rappel ob_start, utilise gzip pour compresser le contenu du tampon. ob_list_handlers
//Liste de tous les gestionnaires de sortie utilisés
output_add_rewrite_var //Ajouter des valeurs de réécriture d'URL
output_reset_rewrite_vars //Réinitialiser les valeurs de réécriture d'URL
这些函数的行为受php_ini设置的影响:
output_buffering //该值为ON时,将在所有脚本中使用输出控制;若该值为一个数字,则代表缓冲区的最大字节限制,当缓存内容达到该上限时将会自动向浏览器输出当前的缓冲区里的内容。
output_handler //该选项可将脚本所有的输出,重定向到一个函数。例如,将 output_handler 设置为 mb_output_handler() 时,字符的编码将被修改为指定的编码。设置的任何处理函数,将自动的处理输出缓冲。
implicit_flush //作用同ob_implicit_flush,默认为Off。
二、实例讲解
1、使 header() 函数前可以有echo代码
Output Control 函数可以让你自由控制脚本中数据的输出。它非常地有用,特别是对于:当你想在数据已经输出后,再输出文件头的情况。
输出控制函数不对使用 header() 或 setcookie(),发送的文件头信息产生影响,只对那些类似于 echo() 和 PHP 代码的数据块有作用。
ob_start(); //打开缓冲区 echo "Hello\n"; //输出 header(“location:index.php”); //把浏览器重定向到index.php ob_end_flush(); //输出全部内容到浏览器
所有对header()函数有了解的人都知道,这个函数会发送一段文件头给浏览器,但是如果在使用这个函数之前已经有了任何输出(包括空输出,比如空格,回车和换行)就会提示出错。如果我们去掉第一行的ob_start(),再执行此程序,我们会发现得到了一条错误提示:"Header had all ready send by"!但是加上ob_start,就不会提示出错,原因是当打开了缓冲区,echo后面的字符不会输出到浏览器,而是保留在服务器,直到你使用flush或者ob_end_flush才会输出,所以并不会有任何文件头输出的错误!
2、保存 phpinfo() 函数的输出
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
3、静态模版技术
所谓静态模版技术就是通过某种方式,使得用户在client端得到的是由PHP产生的html页面。如果这个html页面不会再被更新,那么当另外的用户再次浏览此页面时,程序将不会再调用PHP以及相关的数据库,对于某些信息量比较大的网站,例如sina、163、sohu。类似这种的技术带来的好处是非常巨大的。
ob_start(); //打开缓冲区 php页面的全部输出 $content = ob_get_contents(); //取得php页面输出的全部内容 $fp = fopen("output00001.html", "w"); //创建一个文件,并打开,准备写入 fwrite($fp, $content); //把php页面的内容全部写入output00001.html,然后…… fclose($fp);
三、输出缓存句柄ob_gzhandler
PHP4.0.4有一个新的输出缓存句柄ob_gzhandler,它与前面的类相似,但用法不同。使用ob_gzhandler时要在php.ini中加入的内容如下:
output_handler = ob_gzhandler;
这行代码使得PHP激活输出缓存,并压缩它发送出去的所有内容。
如果由于某种原因你不想在php.ini中加上这行代码,你还可以通过PHP源文件所在目录的.htaccess文件改变默认的服务器行为(不压缩),语法如下:
php_value output_handler ob_gzhandler
或者是从PHP代码调用,如下所示:
ob_start("ob_gzhandler");
采用输出缓存句柄的方法确实非常有效,而且不会给服务器带来什么特殊的负荷。但必须注意的是,Netscape Communicator对压缩图形的支持不佳,因此除非你能够保证所有用户都使用IE浏览器,否则你应该禁止压缩JPEG和GIF图形。一般地,对于所有其他文件,这种压缩都有效,但建议你针对各种浏览器都分别进行测试,特别是当你使用了特殊的插件或者数据查看器时这一点尤其重要。
注意事项:
1、一些Web服务器的output_buffering默认是4069字符或者更大,即输出内容必须达到4069字符服务器才会flush刷新输出缓冲,为了确保flush有效,最好在ob_flush()函数前有以下语句:
print str_repeat("", 4096); //以确保到达output_buffering值
2、ob_* 系列函数是操作PHP本身的输出缓冲区,所以ob_flush只刷新PHP自身的缓冲区,而flush是刷新apache的缓冲区。所以,正确使用俩者的顺序是:先ob_flush,然后flush。ob_flush是把数据从PHP的缓冲中释放出来,flush是把缓冲内/外的数据全部发送到浏览器。
3、不要误认为用了ob_start()后,脚本的echo/print等输出就永远不会显示在浏览器上了。因为PHP脚本运行结束后,会自动刷新缓冲区并输出内容。
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!