먼저 코드를 살펴보겠습니다.
〈?php
for ($i=10; $i〉0; $i--)
{
echo $i
플러시 () ;
sleep(1);
}
?〉
PHP 매뉴얼에 따르면 이 함수는 지금까지의 프로그램의 모든 출력을 사용자의 브라우저로 보냅니다.
위 코드는 1초마다 $i를 출력해야 합니다. 그러나 실제로는 반드시 그런 것은 아닙니다. 10초 동안 기다린 후 모든 출력이 동시에 표시될 수도 있습니다.
좋습니다. 이 코드를
〈?php
ob_end_clean();//Modify part
for ($i=10; $i〉0; $i- -)
로 변경해 보겠습니다. {
echo $i;
flash();
sleep(1);
}
?>
이 문장을 추가했습니다. 실제로는 괜찮습니다. 실제로 ob_end_clean()을 ob_end_flush()로 대체해도 괜찮습니다.
다시 바꿔보겠습니다.
〈?php
for ($i=10; $i>0; $i--)
{
echo $i
ob_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()가 버퍼링된 데이터를 전송하는데 왜 굳이 Flush()를 사용해야 하는지 궁금하실텐데요??? 그냥 다음 코드만 쓰면 되지 않나요? ?
〈?php
for ($i=10; $i>0; $i--)
{
echo $i
ob_flush()
sleep(1 );
}
?>
ob_flush()와 플러시()의 차이점에 유의하세요. 전자는 PHP의 버퍼에서 데이터를 해제하는 것이고, 후자는 버퍼에 없거나 해제된 데이터를 브라우저로 보내는 것입니다. 따라서 버퍼가 존재하면 ob_flush()와 플러시()를 동시에 사용해야 합니다.
여기서는 Flush()가 필수인가요? 아니요, 데이터가 출력되면 즉시 브라우저로 전송되도록 하는 다른 방법이 있습니다. 다음 두 코드 부분에서는 플러시()를 사용할 필요가 없습니다.(output_buffering을 0으로 설정하면 ob_flush() 및 ob_end_clean()도 필요하지 않습니다.)
〈?php
ob_implicit_flush(true)
for ($i=10; $i 〉0 ; $i--)
{
echo $i;
ob_flush()
sleep(1)
}
?>
ob_end_clean();
ob_implicit_flush(true);
for ($i=10; $i>0; $i--)
{
echo $i; ;
}
?〉
위의 ob_implicit_flush(true)를 참고하세요. 이 함수는 출력이 있을 때마다 즉시 브라우저로 전송됩니다. 이런 방식으로 각 출력(에코) 후에 브라우저에 보내기 위해 플러시()를 사용할 필요가 없습니다.
일부 브라우저에서는 위의 불만사항이 사실이 아닐 수도 있습니다. 브라우저에도 자체 규칙이 있기 때문입니다. 테스트에는 Firefox1.5, IE6, Opera8.5를 사용했습니다. 그 중 오페라는 HTML 태그를 만나지 않으면 스크립트가 끝나지 않으면 절대로 출력하지 않는다는 규칙이 있어서 정상적으로 출력할 수 없습니다. FireFox와 IE는 비교적 정상입니다.
마지막으로 PuTTYshell이 작성한 매우 흥미로운 코드가 있습니다. 스크립트 주기에서 각 출력은 이전 출력을 덮어씁니다.
다음 코드는 Firefox에서만 사용할 수 있습니다. 다른 브라우저는 multipart/x-mixed-replace의 Content-Type을 지원하지 않습니다.
〈?php
header('Content-type: multipart/x- Mixed -replace;boundary=endofsection');
인쇄 “n--endofsectionn“
$pmt = array(“-“, “\“, “|“, “/“); ( $i = 0; $i 〈10; $i ){
sleep(1)
인쇄 "콘텐츠 유형: text/plainnn"
"부분 $it".$pmt[ $ i % 4];
인쇄 "--endofsectionn";
플러시()
인쇄 "콘텐츠 유형: text/plainnn"; endn“;
인쇄 “--endofsection--n“
?〉
위에서는 PHP의 출력 버퍼링 분석을 그 측면을 포함하여 소개했습니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.