|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
在学习HTML中我想边学边做是最有效的方式,当然这一方式对于学习PHP同样是最有效的。 Output Control 函数可让你自在掌握剧本中数据的输入。它十分地有效,出格是关于:当你想
在数据已输入后,再输入文件头的情形。输入掌握函数不合错误利用 header() 或 setcookie(),
发送的文件头信息发生影响,只对那些相似于 echo() 和 PHP 代码的数据块有感化。
咱们先举一个复杂的例子,让人人对Output Control有一个大致的印象:
Example 1.
ob_start(); //翻开缓冲区
echo "Hello\n"; //输入
header(“location:index.php”); //把阅读重视定向到index.php
ob_end_flush();//输入全体内容到阅读器
?>
一切对header()函数有懂得的人都晓得,这个函数会发送一段文件头给阅读器,然而假如在利用
这个函数之前已有了任何输入(包含空输入,好比空格,回车和换行)就会提醒失足。假如我
们去失落第一行的ob_start(),再履行此法式,咱们会发明失掉了一条毛病提醒:“Header had
all ready send by”!然而加上ob_start,就不会提醒失足,缘由是当翻开了缓冲区,echo前面
的字符不会输入到阅读器,而是保存在办事器,直到你利用flush或ob_end_flush才会输入,所
以其实不会有任何文件头输入的毛病!
1、 相干函数简介:
1、Flush:刷新缓冲区的内容,输入。
函数格局:flush()
申明:这个函数常常利用,效力很高。
2、ob_start :翻开输入缓冲区
函数格局:void ob_start(void)
申明:当缓冲区激活时,一切来自PHP法式的非文件头信息均不会发送,而是保留在外部缓冲区。
为了输入缓冲区的内容,可使用ob_end_flush()或flush()输入缓冲区的内容。
3 、ob_get_contents :前往外部缓冲区的内容。
利用办法:string ob_get_contents(void)
申明:这个函数会前往以后缓冲区中的内容,假如输入缓冲区没有激活,则前往 FALSE 。
4、ob_get_length:前往外部缓冲区的长度。
利用办法:int ob_get_length(void)
申明:这个函数会前往以后缓冲区中的长度;和ob_get_contents一样,假如输入缓冲区没有激
活。则前往 FALSE。
5、ob_end_flush :发送外部缓冲区的内容到阅读器,而且封闭输入缓冲区。
利用办法:void ob_end_flush(void)
申明:这个函数发送输入缓冲区的内容(假如有的话)。
6、ob_end_clean:删除外部缓冲区的内容,而且封闭外部缓冲区
利用办法:void ob_end_clean(void)
申明:这个函数不会输入外部缓冲区的内容而是把它删除!
7、ob_implicit_flush:翻开或封闭相对刷新
利用办法:void ob_implicit_flush ([int flag])
申明:利用过Perl的人都晓得$│=x的意义,这个字符串可以翻开/封闭缓冲区,而
ob_implicit_flush函数也和谁人一样,默许为封闭缓冲区,翻开相对输入后,每一个剧本输入都直
接发送到阅读器,不再需求挪用 flush()
2、深切懂得:
1. 关于Flush函数:
这个函数在PHP3中就呈现了,是一个效力很高的函数,他有一个十分有效的功效就是刷新browser
的cache.咱们举一个运转后果十分分明的例子来讲明flush.
Example 2.
---------------------------------------------------------
for($i = 1; $i <= 300; $i++ ) print(“ “);
// 这一句话十分关头,cache的布局使得它的内容只要到达必定的巨细才干从阅读器里输入
// 换言之,假如cache的内容不到达必定的巨细,它是不会在法式履行终了前输入的。经
// 过测试,我发明这个巨细的底限是256个字符长。这意味着cache今后吸收的内容城市
// 源源不休的被发送出去。
For($j = 1; $j <= 20; $j++) {
echo $j.”
”;
flush(); //这一部会使cache新增的内容被挤出去,显示到阅读器上
sleep(1); //让法式“睡”一秒钟,会让你把后果看得更清晰
}
?>
-----------------------------------------------------------
注:假如在法式的首部到场ob_implicit_flush()翻开相对刷新,就能够在法式中不再利用flush
(),如许做的优点是:进步效力!
2. 关于ob系列函数:
我想先援用我的好伴侣y10k的一个例子:
Example 3.
---------------------------------------------------------
好比你用失掉办事器和客户真个设相信息,然而这个信息会由于客户真个分歧而分歧,假如想要
保留phpinfo()函数的输入怎样办呢?在没有缓冲区掌握之前,可以说一点举措也没有,然而有了
缓冲区的掌握,咱们可以轻松的处理:
-------------------------------------------------------------
ob_start(); //翻开缓冲区
phpinfo(); //利用phpinfo函数
$info=ob_get_contents(); //失掉缓冲区的内容而且赋值给$info
$file=fopen('info.txt','w'); //翻开文件info.txt
fwrite($file,$info); //写入信息到info.txt
fclose($file); //封闭文件info.txt
?>
-------------------------------------------------------------
用以上的办法,就能够把分歧用户的phpinfo信息保留上去,这在之前生怕没有举措办到!其实上
面就是将一些“进程”转化为“函数”的办法!
也许有人会问:“岂非就这个模样吗?还有无其他用处?”固然有了,好比笔者服装论坛的PHP 语
法加亮显示就和这个有关(PHP默许的语法加亮显示函数会直接输入,不克不及保留了局,假如在每次
挪用都显示生怕会很华侈CPU,笔者的服装论坛就把语法加亮函数显示的了局用掌握缓冲区的办法保存
了)
------------------------------------------------------------
能够如今人人对ob_start()的功效有了必定的懂得,下面的一个例子看似复杂,但实践上已掌
握了利用ob_start()的要点。
<1>.利用ob_start翻开browser的cache,如许可以包管cache的内容在你挪用flush
(),ob_end_flush()(或法式履行终了)之前不会被输入。
<2>.如今的你应当晓得你所具有的优势:可以在任何输入内容前面利用header,setcookie和
session,这是ob_start一个很大的特色;也能够利用ob_start的参数,在cache被写入后,然后
主动运转号令,好比ob_start("ob_gzhandler");而咱们最经常使用的做法是用ob_get_contents()得
到cache中的内容,然后再停止处置……
<3>.当处置终了后,咱们可使用各类办法输入,flush(),ob_end_flush(),和比及法式履行完
毕后的主动输入。固然,假如你用的是ob_get_contents(),那末就要你本人掌握输入体例了。
来,让咱们看看能用ob系列函数做些甚么……
1、 静态模版手艺
简介:所谓静态模版手艺就是经由过程某种体例,使得用户在client端失掉的是由PHP发生的html页
面。假如这个html页面不会再被更新,那末当别的的用户再次阅读此页面时,法式将不会再挪用
PHP和相干的数据库,关于某些信息量对照大的网站,例如sina,163,sohu。相似这类的手艺带
来的优点长短常伟大的。
我所晓得的完成静态输入的有两种举措:
<1>.经由过程y10k修正的phplib的一个叫template.inc.php类完成。
<2>.利用ob系列函数完成。
关于第一种办法,由于不是这篇文章所要研讨的成绩,所以不再赘述。
咱们如今来看一看第二种办法的详细完成:
Example 4.
ob_start();//翻开缓冲区
?>
php页面的全体输入
$content = ob_get_contents();//获得php页面输入的全体内容
$fp = fopen(“output00001.html”, “w”); //创立一个文件,并翻开,筹办写入
fwrite($fp, $content); //把php页面的内容全体写入output00001.html,然后……
fclose($fp);
?>
如许,所谓的静态模版就很轻易的被完成了……
2、 捕获输入
以上的Example 4.是一种最复杂的情形,你还可以在写入前对$content停止操作……
你可以想法捕获一些关头字,然后去对它停止再处置,好比Example 3.所述的PHP语法高亮显示。
团体以为,这个功效是此函数最大的精髓地点,它可以处理各类各样的成绩,但需求你有足够的
想象力……
Example 5.
Function run_code($code) {
If($code) {
ob_start();
eval($code);
$contents = ob_get_contents();
ob_end_clean();
}else {
echo “毛病!没有输入”;
exit();
}
return $contents;
}
以上这个例子的用处不是很大,不外很典范$code的自己就是一个含有变量的输入页面,而这个例
子用eval把$code中的变量交换,然后对输入了局再停止输入捕获,再一次的停止处置……
Example 6. 加速传输
/*
** Title.........: PHP4 HTTP Compression Speeds up the Web
** Version.......: 1.20
** Author........: catoc
** Filename......: gzdoc.php
** Last changed..: 18/10/2000
** Requirments...: PHP4 >= 4.0.1
** PHP was configured with --with-zlib[=DIR]
** Notes.........: Dynamic Content Acceleration compresses
** the data transmission data on the fly
** code by sun jin hu (catoc)
** Most newer browsers since 1998/1999 have
** been equipped to support the HTTP 1.1
** standard known as "content-encoding."
** Essentially the browser indicates to the
** server that it can accept "content encoding"
** and if the server is capable it will then
** compress the data and transmit it. The
** browser decompresses it and then renders
** the page.
**
** Modified by John Lim (jlim@natsoft.com.my)
** based on ideas by Sandy McArthur, Jr
** Usage........:
** No space before the beginning of the first ' ** ------------Start of file---------
-
** │ ** │ include('gzdoc.php');
** │? >
** │
** │... the page ...
** │
** │ ** │ gzdocout();
** │? >
** -------------End of file-----------
*/
ob_start();
ob_implicit_flush(0);
function CheckCanGzip(){
global $HTTP_ACCEPT_ENCODING;
if (headers_sent() ││ connection_timeout() ││ connection_aborted()){
return 0;
}
if (strpos($HTTP_ACCEPT_ENCODING, 'x-gzip') !== false) return "x-gzip";
if (strpos($HTTP_ACCEPT_ENCODING,'gzip') !== false) return "gzip";
return 0;
}
/* $level = compression level 0-9, 0=none, 9=max */
function GzDocOut($level=1,$debug=0){
$ENCODING = CheckCanGzip();
if ($ENCODING){
print "\n\n";
$Contents = ob_get_contents();
ob_end_clean();
if ($debug){
$s = "
Not compress length: ".strlen($Contents);
$s .= "
Compressed length: ".strlen(gzcompress($Contents,$level));
$Contents .= $s;
}
header("Content-Encoding: $ENCODING");
print "\x1f\x8b\x08\x00\x00\x00\x00\x00";
$Size = strlen($Contents);
$Crc = crc32($Contents);
$Contents = gzcompress($Contents,$level);
$Contents = substr($Contents, 0, strlen($Contents) - 4);
print $Contents;
print pack('V',$Crc);
print pack('V',$Size);
exit;
}else{
ob_end_flush();
exit;
}
}
?>
这是catoc的一段很早之前的代码,是在weblogs.com看到的,他使用了zlib的函数,对传输的内
容停止了紧缩,测试标明,关于10k以上的页面,会发生后果,并且页面越大,后果越分明……
应该大致熟悉了一些学习过程,也许我的过程和你的有些出路,但是不管怎么样是殊途同归,我写这么多,也只是给大家一个借鉴的机会,至于好与不好,默默不敢打包票^0^ |
|