微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP flush 函数使用注意事项

ob_*系列函数,是操作PHP本身的输出缓冲区.

所以,ob_flush是刷新PHP自身的缓冲区.

而flush,严格来讲,这个只有在PHP做为apache的Module(handler或者filter)安装的时候,才有实际作用. 它是刷新WebServer(可以认为特指apache)的缓冲区.

在apache module的sapi下,flush会通过调用sapi_module的flush成员函数指针, 间接的调用apache的api: ap_rflush刷新apache的输出缓冲区,当然手册中也说了,有一些apache的其他模块, 可能会改变这个动作的结果..

有些Apache的模块,比如mod_gzip,可能自己进行输出缓存,这将导致flush()函数产生的结果不会立即被发送到客户端浏览器。

甚至浏览器也会在显示之前,缓存接收到的内容。例如 netscape浏览器会在接受到换行或 html标记的开头之前缓存内容,并且在接受到 标记之前,不会显示出整个表格。

一些版本的 Microsoft Internet Explorer 只有当接受到的256个字节以后才开始显示页面,所以必须发送一些额外的空格来让这些浏览器显示页面内容

所以,正确使用俩者的顺序是. 先ob_flush,然后flush,

当然,在其他sapi下,不调用flush也可以,只不过为了保证你代码的可移植性,建议配套使用.

rush:PHP;"> 0) { $time = date('r'); echo "data: The server time is: {$time}\n\n"; ob_flush(); flush();//break; sleep(1); $long --; } // var source=new EventSource("http://localhost:18000/sse.PHP");source.onmessage=function(event){console.info(event.data)}; ?>

如果要在 Nginx + fpm + PHP支持需要加一个响应头

header('X-Accel-Buffering: no'); This eliminates both proxy_buffering and (if you have Nginx >= 1.5.6),fastcgi_buffering. The fastcgi bit is crucial if you're using PHP-fpm. The header is also far more convenient to do on an as-needed basis. Docs on X-Accel-Buffering Nginx.org/en/docs/http/ngx_http_fastcgi_module.html#fastcgi_buffering">http://Nginx.org/en/docs/http/ngx_http_fastcgi_module.html#fastcgi_buffering ;

rush:PHP;"> // ob_end_flush();
// ini_set('output_buffering',1);

// if (ob_get_level() == 0) ob_start();
// echo str_repeat(' ',4096);

$long = 60;
while($long > 0)
{
$time = date('r');
echo "data: The server time is: {$time}\n\n";
ob_flush();

flush();//break;
sleep(1);
$long --;

}
// var source=new EventSource("http://localhost:18000/sse.PHP");source.onmessage=function(event){console.info(event.data)};
?>

原文地址:https://www.jb51.cc/php/19118.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐