>백엔드 개발 >PHP 튜토리얼 >ob 시리즈 함수 출력 캐시 사용법에 대한 자세한 설명

ob 시리즈 함수 출력 캐시 사용법에 대한 자세한 설명

伊谢尔伦
伊谢尔伦원래의
2017-06-24 11:49:251555검색

ob, 출력 버퍼는 출력 캐시가 아닌 출력 버퍼링의 약어입니다. ob를 올바르게 사용하면 어느 정도 속도에 도움이 될 수 있지만, ob 기능을 무턱대고 추가하면 CPU에 추가 부담만 가중될 뿐입니다. ob의 기본 원리: ob 캐시를 켜면 에코 데이터가 뜹니다. 먼저 ob 캐시에 배치됩니다. 헤더 정보인 경우 프로그램 캐시에 직접 배치됩니다. 페이지가 끝까지 실행되면 ob 캐시된 데이터가 프로그램 캐시에 저장되었다가 차례로 브라우저로 반환됩니다.

ob의 기본 기능에 대해 이야기해 보겠습니다.
1) 브라우저 출력 후 헤더 파일을 보내기 위해 setcookie(), header() 또는 session_start()와 같은 함수를 사용하여 발생하는 오류를 방지합니다. 실제로 이런 종류의 사용법을 덜 자주 사용하고 좋은 코딩 습관을 기르는 것이 더 좋습니다.
2) 일부 얻을 수 없는 함수의 출력을 캡처합니다. 예를 들어 phpinfo()는 많은 HTML을 출력하지만 현재로서는 $info=phpinfo()와 같은 변수를 사용하여 캡처할 수 없습니다. 유용한.
3) gzip 압축, 중국어 간체와 번체 간 변환, 일부 문자열 교체 등 출력 콘텐츠를 처리합니다.
4) 정적 파일 생성은 실제로 전체 페이지의 출력을 캡처한 다음 파일로 저장하는 것입니다. HTML 생성이나 전체 페이지 캐싱에 자주 사용됩니다.

방금 언급한 세 번째 항목에서 언급한 GZIP 압축과 관련하여 많은 사람들이 사용하고 싶어도 실제로 사용하지 않았을 수 있습니다. 실제로 코드를 약간만 수정하면 페이지의 gzip 압축을 얻을 수 있습니다.

ob_start(ob_gzhandler);
要缓存的内容

예, 콜백 함수 ob_gzhandler만 추가하면 되지만 여기에는 몇 가지 사소한 문제가 있습니다. 첫째, zlib 지원이 필요하고, 둘째, 브라우저가 gzip을 지원하는지 여부를 확인하지 않습니다(지금은 지원하는 것 같지만, 아이폰 브라우저가 지원하는 것 같습니다) 지원).

이전 접근 방식은 브라우저가 gzip을 지원하는지 확인한 다음 타사 gzip 기능을 사용하여

ob_get_contents
()의 콘텐츠를 압축하고 마지막으로 에코하는 것이었습니다.

1. ob 시리즈 함수에서 자주 사용되는 함수 모음

ob_start(); //출력 버퍼를 엽니다. 모든 출력 정보는 더 이상 브라우저로 직접 전송되지 않고 출력 버퍼에 저장됩니다.

ob_clean(); //버퍼를 닫지 않고(출력 없음) 내부 버퍼의 내용을 삭제합니다.

ob_end_clean(); //내부 버퍼의 내용을 삭제하고 버퍼를 닫습니다(출력 없음).

ob_get_clean(); //내부 버퍼의 내용을 반환하고 버퍼를 닫습니다. ob_get_contents() 및 ob_end_clean()
ob_flush()를 실행하는 것과 동일합니다. //내부 버퍼의 내용을 브라우저로 보내고, 버퍼의 내용을 삭제하고, 버퍼를 닫지 않습니다.
ob_end_flush(); //내부 버퍼의 내용을 브라우저로 보내고 버퍼의 내용을 삭제한 후 버퍼를 닫습니다.
ob_get_flush(); //내부 버퍼의 내용을 반환하고 버퍼를 닫은 다음 버퍼의 내용을 해제합니다. ob_end_flush()와 동일하며 버퍼 내용을 반환합니다.
flush(); //ob_flush에 의해 릴리스된 콘텐츠와 PHP 버퍼에 없는 콘텐츠를 브라우저에 출력합니다. 내부 버퍼의 콘텐츠를 새로 고쳐서 출력합니다.

ob_get_contents(); //출력 없이 버퍼의 내용을 반환합니다.

ob_get_length
(); //내부 버퍼의 길이를 반환합니다. 버퍼가 활성화되지 않은 경우 이 함수는 FALSE를 반환합니다. ob_get_level(); //출력 버퍼링 메커니즘의 중첩 수준을 반환합니다.ob_get_status(); ob_implicit_flush(true)를 연 후 소위 절대 새로 고침은 출력 문(예: echo)이 실행될 때 출력은 플러시()를 호출하거나 출력을 위해 스크립트가 끝날 때까지 기다릴 필요 없이 브라우저로 직접 전송됩니다.

ob_gzhandler //ob_start 콜백 함수, gzip을 사용하여 버퍼 내용을 압축합니다.

ob_list_handlers               //

这些函数的行为受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脚本运行结束后,会自动刷新缓冲区并输出内容。

위 내용은 ob 시리즈 함수 출력 캐시 사용법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.