>백엔드 개발 >PHP 튜토리얼 >PHP 플러시 클래스 출력 버퍼 분석

PHP 플러시 클래스 출력 버퍼 분석

高洛峰
高洛峰원래의
2016-12-22 16:30:14903검색

for ($i=10; $i>0; $i--)
{
echo $i
flush(); 1);
}
?>
PHP 매뉴얼에 따르면
이 함수는 지금까지의 프로그램의 모든 출력을 사용자의 브라우저로 보냅니다.
위 코드는 매초마다 $i를 출력해야 합니다. 그러나 실제로는 반드시 그런 것은 아닙니다. 10초 동안 기다린 후 모든 출력이 동시에 표시될 수도 있습니다.
좋아, 이 코드를
ob_end_clean();//수정 부분
for ($i=10; $i>0; $i --) {
echo $i;
flush();
sleep(1);
?>
이 문장을 추가했습니다. ob_end_clean( ); . 실제로 ob_end_clean()을 ob_end_flush()로 대체해도 괜찮습니다.
다시 바꿔보겠습니다.
for ($i=10; $i>0; $i--)
{
echo $i
ob_flush();//부분 수정
flush();
sleep(1);
}
?> 실행해 보면 $i도 매초 출력되는 것을 알 수 있습니까? 왜 이런가요?
걱정하지 마세요. php.ini를 살펴보겠습니다.
php.ini를 열고 output_buffering을 검색하면 다음과 같은 설정이 표시됩니다.output_buffering = 4096. 이름이 출력_버퍼링인 것처럼 이 설정의 기능은 출력을 버퍼링하는 것입니다. 버퍼 크기는 4096바이트입니다.
첫 번째 코드에서 출력이 예상과 다른 이유는 바로 이 출력 버퍼링이 출력을 버퍼링하기 때문입니다. 모두 버퍼링되었습니다. 4096바이트에 도달하거나 스크립트가 종료되기 전에는 출력이 전송되지 않습니다.
두 번째 코드의 ob_end_clean() 및 ob_end_flush() 함수는 버퍼링을 종료하는 것입니다. 이런 방식으로 전송되기 전에 4096바이트의 버퍼가 있을 때까지 기다릴 필요가 없습니다.
세 번째 코드에서는 ob_flush()가 사용됩니다. 그 기능은 버퍼링된 데이터를 보내는 것이지만 버퍼링을 종료하지 않으므로 각 플러시() 전에 사용해야 합니다.
ob_end_clean(), ob_end_flush() 및 ob_flush()를 사용하지 않으려면 php.ini에서 output_buffering을 충분히 작게 설정해야 합니다(예: 0으로 설정). ini_set("output_buffering","0")을 사용하여 스크립트에 설정하려는 경우 중지하십시오. 이 방법은 작동하지 않습니다. 스크립트 시작 부분에서 버퍼링 설정이 로드된 다음 버퍼링이 시작되기 때문입니다.
ob_flush()가 버퍼링된 데이터를 전송하는데 왜 굳이 플러시()를 사용해야 하느냐고 질문하실 수도 있습니다. 그냥 다음 코드를 사용하면 안 되나요? ?
for ($i=10; $i>0; $i--)
{
echo $i
ob_flush()
sleep( 1);
}
?>
ob_flush()와 플러시()의 차이점에 유의하세요. 전자는 PHP의 버퍼에서 데이터를 해제하는 것이고, 후자는 버퍼에 없거나 해제된 데이터를 브라우저로 보내는 것입니다. 따라서 버퍼가 존재하면 ob_flush()와 플러시()를 동시에 사용해야 합니다.
여기서 플러시()는 필수인가요? 아니요, 데이터가 출력되면 즉시 브라우저로 전송되도록 하는 다른 방법이 있습니다. 다음 두 코드 부분에서는 플러시()를 사용할 필요가 없습니다. (output_buffering을 0으로 설정하면 ob_flush() 및 ob_end_clean()도 필요하지 않습니다.)
ob_implicit_flush(true)
for ($i=10; $ i> 0; $i--)
{
echo $i;
sleep(1)
?>
ob_end_clean();
ob_implicit_flush(true);
for ($i=10; $i>0; $i--)
{
echo $i; (1);
}
?>
위의 ob_implicit_flush(true)에 유의하세요. 이 함수는 출력이 있을 때마다 즉시 브라우저로 전송됩니다. 이런 방식으로 각 출력(에코) 후에 브라우저에 보내기 위해 플러시()를 사용할 필요가 없습니다.
일부 브라우저에서는 위의 불만사항이 사실이 아닐 수도 있습니다. 브라우저에도 자체 규칙이 있기 때문입니다. 테스트에는 Firefox1.5, IE6, Opera8.5를 사용했습니다. 그 중 오페라는 HTML 태그를 만나지 않으면 스크립트가 끝나지 않으면 절대로 출력하지 않는다는 규칙이 있어서 정상적으로 출력할 수 없습니다. FireFox와 IE는 비교적 정상입니다.
마지막으로 PuTTYshell이 ​​작성한 매우 흥미로운 코드가 첨부되었습니다. 스크립트 주기에서 각 출력은 이전 출력을 덮어씁니다.
다음 코드는 Firefox에서만 사용할 수 있습니다. 다른 브라우저는 multipart/x-mixed-replace의 Content-Type을 지원하지 않습니다.
header('Content-type: multipart/x -mixed-replace;boundary=endofsection');
print "n--endofsectionn";
$pmt = array("-", "\", "|", "/" ); for ( $i = 0; $i <10; $i ++ ){
sleep(1)
print "Content-type: text/plainnn";print "Part $it".$pmt[$i % 4];
print "--endofsectionn";
ob_flush()
flush(); -type: text/plainnn";
"The endn" 인쇄;
인쇄 "--endofsection--n";
?>



PHP 플러시 출력 버퍼 분석과 관련된 더 많은 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!

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