php怎么关闭ob_start
时间:2022-02-11 13:53
php ob_start用于打开输出控制缓冲,其实现关闭ob_start则可以使用ob_end_clean()函数静默丢弃掉缓冲区的内容。 本文操作环境:windows7系统、PHP7.1版、DELL G3电脑 php怎么关闭ob_start? ob_start — 打开输出控制缓冲 说明 此函数将打开输出缓冲。当输出缓冲激活后,脚本将不会输出内容(除http标头外),相反需要输出的内容被存储在内部缓冲区中。 内部缓冲区的内容可以用 警告 当有正在调用的回调函数时,一些网络服务器(例如Apache)会改变一个脚本的工作目录。 你可以在回调函数中再把它改回来,例如 chdir(dirname($_SERVER['SCRIPT_FILENAME'])) 。 输出缓冲区是可堆叠的,这即意谓着,当有一个 ob_start() 是活跃的时, 你可以调用另一个 ob_start() 。 只要确保又正确调用了 ob_end_flush() 恰当的次数即可。 如果有多重输出回调函数是活跃的,输出内容会一直按嵌套的顺序依次通过它们而被过滤。 参数 output_callback 可选参数 output_callback 函数可以被指定。 此函数把一个字符串当作参数并返回一个字符串。 当输出缓冲区被( ob_flush(), ob_clean() 或者相似的函数)冲刷(送出)或者被清洗的时候;或者在请求结束之际输出缓冲区内容被冲刷到浏览器的时候该函数将会被调用。 当调用 output_callback 时,它将收到输出缓冲区的内容作为参数 并预期返回一个新的输出缓冲区作为结果,这个新返回的输出缓冲区内容将被送到浏览器。 如果这个 output_callback 不是一个可以调用的函数,此函数 会返回 false。 以下是回调签名: buffer 输出缓冲区中的内容。 phase 比特掩码 PHP_OUTPUT_HANDLER_* 常量。 如果 output_callback 返回 false ,其原来的输入 内容被直接送到浏览器。 这个参数 output_callback 可以通过直接给一个 null 值而避开。 ob_end_clean(), ob_end_flush(), ob_clean(), ob_flush() 和 ob_start() 不能从一个回调函数中调用。 如果从回调函数中调用了它们,产生的行为是不明确的。 如果想要删除缓冲区的内容,从回调函数中返回一个"" (空字符串)。 更不能从一个回调函数中使用像print_r($expression, true) 或highlight_file($filename, true) 一样的输出缓冲函数。 chunk_size 如果可选参数 chunk_size 被赋值了,在任何一个能引起缓冲区的长度等于 或超过 chunk_size 的输出操作后,缓冲区都会被刷送。 默认值 0 意味着函数仅在最后被调用。 PHP 5.4.0 之前,1 是一个特殊情况下的值,代表将 chunk_size 设置为 4096 字节。 flags flags 参数代表了一个掩码位,用来控制对缓冲区的操作。 The default is to allow output buffers to be cleaned, flushed and removed, which can be set explicitly via PHP_OUTPUT_HANDLER_CLEANABLE | PHP_OUTPUT_HANDLER_FLUSHABLE | PHP_OUTPUT_HANDLER_REMOVABLE, or PHP_OUTPUT_HANDLER_STDFLAGS as shorthand. 返回值 成功时返回 true, 或者在失败时返回 false。 推荐学习:《PHP视频教程》 以上就是php怎么关闭ob_start的详细内容,更多请关注gxlsystem其它相关文章!ob_start(callable $output_callback = null, int $chunk_size = 0, int $flags = PHP_OUTPUT_HANDLER_STDFLAGS): bool
ob_get_contents()
函数复制到一个字符串变量中。 想要输出存储在内部缓冲区中的内容,可以使用 ob_end_flush()
函数。另外, 使用 ob_end_clean()
函数会静默丢弃掉缓冲区的内容。handler(string $buffer, int $phase = ?): string
注意:
ob_gzhandler() function exists to facilitate sending gz-encoded data to web browsers that support compressed web pages. ob_gzhandler() determines what type of content encoding the browser will accept and will return its output accordingly.