我个人认为,output buffering是比较纯粹的4.0特征。尽管从概念上看来相当简单,但是output buffering功能非常强大,能使开发者更容易地开发高级而有效的程序。
本文将介绍http header,以及output buffering如何帮助您处理http header,并介绍了output buffering的一些高级用法。
http header
对 于使用http 协议建立的每个请求,web服务器产生的响应通常包括两个部分 – 标题和主体。例如,如果在web服务器的文档根目录下有一个小文本文件,叫做example.txt,文件中包含文本hello, world!,那么对此文件的http 请求响应如下所示:
复制代码 代码如下:
http/1.1 200 ok
date: sat, 02 p 2000 21:40:08 gmt
rver: apache/1.3.11 (unix) mod_macro/1.1.1 php/4.0.2-dev
last-modified: sat, 02 p 2000 21:39:49 gmt
etag: “12600b-e-39b173a5”
accept-ranges: bytes
content-length: 14
connection: closstrong的反义词e
content-type: text/plain
hello, world!
这 个请求中的第一部分(就是较多的那部分)就是http header。虽然用户在浏览器中看不到http header,但它包含了用于浏览器的信息,例如文档内容类型,使用的协议版本,文档的最后更改日期等等。http header并没有太多的规则,通常情况下,它的格式如下:
复制代码 代码如下:
field: value[字段:值]
必须用空行将它们和文档主体分开。
可以从php脚本添加或更改此http header的信息。例如,可以使用 header() 函数:
复制代码 代码如下:
header(“location: /d/file/titlepic/arch.php // 重定向到 /d/file/titlepic/manual-lookup.php />
也可以使用 tcookie() 函数:
复制代码 代码如下:
tcookie(“foo”, “bar”);
你可能会知道http cookies是使用 http headers 来实现的。例如,以下php文件的 http 请求响应
复制代码 代码如下:
<?php
tcookie(“foo”, “bar”);
print “t cookie.”;
?>
将会是这样的:
复制代码 代码如下:
http/1.1 200 ok
date: sat, 02 p 2000 21:43:02 gmt
rver: apache/1.3.11 (unix) mod_macro/1.1.1php/4.0.2-dev
x-powered-by: php/4.0.2-dev
t-cookie: foo=bar
connection: clo
content-type: text/html
t cookie.
浏览器读取从服务器返回的 http header,知道送来了一个叫做 foo 的 cookie (在这里是一个 ssion cookie),它的值是 bar。
为什么要使用output buffering技术
早 在php/fi 2.0时就很明显需要output buffering技术了。如果你使用过这种版本的php,那么可能还记得经常会碰到 oops, tcookie called after header has been nt 这个错误消息,并使你捎头抓耳,也弄不清是什么原因。
如 果你已使用过php的最新版本 — php 3.0 甚至 php 4.0 — 那么你会知道这个错误消息: oops, php_t_cookie called after header has been nt。或者,你在试图调用 php 的 header() 函数时会遇到 cannot add header information – headers already nt 消息。一般来说,output buffering技术用户避免这些烦人的错误消息,同时开发人员也可用于高级的用途。
这些错误是什么时候产生的呢?如果你在已经发送了http header之后试图添加或修改标题信息,以及在文档主体和标题之间缺少空行时,就会产生这些错误消息。为了理解这是如何产生的,让我们来看看php是如何处理http header输出和主体输出的。
脚本开始执行时,它可英语等级有几级以同时发送header(标题)信息和主体信息。
header信息(来自 header() 或 tcookie() 函数)并不会立即发送,相反,它被保存到一个列表中。
这样就可以允许你修改标题信息,包括缺省的标题(例如 content-type 标题)。但是,一旦脚本发送了任何非标题的输出(例如,使用块或 print() 调用),那么php就必须先发送所有的标题,然后再送出空行,终止 http header,而在此之后才会继续发送主体数据。从这时开始,任何添加或修改标题信息的试图都是不允许的,并会发送上述的错误消息之一。
虽然这并不会引起多大的问题,有时候只是在发出任何输入之前终止http header,从而引起脚本逻辑的复杂化而已。output buffering技术可以解决这些问题。
output buffering的工作原理
启用output buffering时,在脚本发送输出时,php并 不发送http header。相反,它将此输出通过管道(pipe)输入到动态增加的缓存中(只能在php 4.0中使用,它具有中央化的输出机制)。你仍然可以修改,添加标题行,或者设置cookie,因为标题实际上并没有发送。最简单的情况是,当脚本终止 时,php将自动发送http header到浏览器,然后再发送输出缓冲中的内容。这简单吧。
基本用法
可以使用下面的四个函数,它们可以帮助你控制output buffering:
复制代码 代码如下:
ob_start()
启用output buffering机制。
output buffering支持多层次 — 例如,可以多次调用 ob_start() 函数。
ob_end_flush()
发送output buffer(输出缓冲)并禁用output buffering机制。
ob_end_clean()
清除output buffer但不发送,并禁用output buffering。
ob_get_contents()
将当前的output buffer返回成一个字符串。允许你处理脚本发出的任何输出。
此外,可以启用 php.ini 中的 output_buffering 指令。如果启用了此指令,那么每个php脚本都相当于一开始就调用了ob_start()函数。
example 1
复制代码 代码如下:
<?php ob_start(); ?>
&内存故障lt;h1>北京婚姻调查;example 1</h1>
<?php
print “hello, $ur “;
tcookie(“wow”, “this cookie has been t even though we’ve already emi大悲咒念诵mp3下载tted output!”);
?>
这里,尽管你已发送了输出(html代 码块中和 print 语句中),也可以使用 tcookie() 调用,而不会出错,真的要感谢output buffering机制。请注意使用output buffering机制用于这种目的会引起一定程度上的性能损失,因此最好缺省情况下不要启用此机制。但是,对于复杂一些的脚本,output buffering可以简化逻辑性。
example 2
复制代码 代码如下:
<?php
ob_start();
print “here’s a pretty dumb way to calculate the length of a string.”;
$length = strlen(ob_get_buffer());
ob_end_clean();
?>
这个例子显示了一个效率很低的确定字符串长度的。它不是简单的使用strlen()函数处理,而是先启用 output buffering 机制,将字符串打印出来,然后再确定output buffer的长度。最后清除output buffer(并没有发送),然后禁用output buffering机制。
本文发布于:2023-04-06 10:24:27,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/42ceb222aeb7476aed391bb86664d7ae.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:PHP中的output.doc
本文 PDF 下载地址:PHP中的output.pdf
留言与评论(共有 0 条评论) |