总有人间一两风,填我十万八千梦

PHP ob_get_clean 用法 手册 | 示例代码

PHP开发手册 归档 330℃ 0评论

ob_get_clean

(PHP 4 >= 4.3.0, PHP 5, PHP 7)

ob_get_clean得到当前缓冲区的内容并删除当前输出缓。

说明

ob_get_clean ( void ) : string

得到当前缓冲区的内容并删除当前输出缓冲区。

ob_get_clean() 实质上是一起执行了 ob_get_contents()ob_end_clean()

返回值

返回输出缓冲区的内容,并结束输出缓冲区。如果输出缓冲区不是活跃的,即返回 FALSE

范例

Example #1 A simple ob_get_clean() example

<?php

ob_start();

echo "Hello World";

$out ob_get_clean();
$out strtolower($out);

var_dump($out);
?>

以上例程会输出:


string(11) "hello world"

参见

用户贡献的笔记

geo dot artemenko at gmail dot com

The definition should mention that the function also "turns off output buffering", not just cleans it.

steven at bielik dot com

Also, don't forget that you will need to ob_start() again for any successive calls:

<?php
ob_start
();
echo
"1";
$content = ob_get_clean();

ob_start(); // This is NECESSARY for the next ob_get_clean() to work as intended.
echo "2";
$content .= ob_get_clean();

echo $content;
?>

Output: 12

Without the second ob_start(), the output is 21 ...

paul+phpnet at earth2me dot com

Keep in mind that output may be buffered by default, depending on how you are running PHP (CGI, CLI, etc.).   You can use ob_get_level() to determine if an output buffer has already been started.  On most web servers I've used, output buffering is already one level deep before my scripts start running.

You should only end as many output buffers as you start.  Assuming that your buffer is always the first buffer, or otherwise closing pre-existing buffers, could lead to problems.  In PHP 5.5, you can ensure that output buffers are ended properly using a try-finally block.

Something like this is almost guaranteed to break stuff:

<?php
// Don't ever do this!
while (ob_get_level() > 1)
{
   
ob_end_flush();
}

$content = ob_get_clean();
?>

The problem is that number, "1".  Using a fixed number there is asking for trouble.  Instead, use ob_get_level() to get the number of output buffers applied when your code starts, and return to that number, if you really must use an unknown number of output buffers:

<?php
ob_start
();
$saved_ob_level = ob_get_level();

// Do stuff here:
run_something();

// If you really must close all of your output buffers except one, this'll do it:
while (ob_get_level() > $start_ob_level)
{
   
ob_end_flush();
}

// And now, the final output buffer that belongs to us:
$content = ob_get_clean();
?>

sergei dot solomonov at gmail dot com

<?php
ob_start
();
echo
"1";
$content = ob_get_clean();

echo "2";
$content .= ob_get_clean();

echo $content;
?>

This script outputs 21 in CLI mode and 12 otherwise (under my apache and nginx)

Peter Smartt

I was trying to debug my code using error_log() and I discovered that ob_get_clean() also truncates the error_log() buffer right in the middle of its output, and well as the output buffer which it is supposed to truncate.  If you are using error_log(), use ob_get_contents() and ob_end_clean() instead of ob_get_clean().

ludvig dot ericson at gmail dot com

Notice that the function beneath does not catch errors, so throw in an @ before those ob_* calls

转载请注明:悠然品鉴 » PHP ob_get_clean 用法 手册 | 示例代码

喜欢 (0)or分享 (0)
发表我的评论
取消评论

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址