PHP编程:经常使用技能:用PHP掌握您的阅读器cache
在学习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 ()
申明:利用过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^ 我还是强烈建议自己搭建php环境。因为在搭建的过程中你会遇到一些问题,通过搜索或是看php手册解决问题后,你会更加深刻的理解它们的工作原理,了解到php配置文件中的一些选项设置。 刚开始安装php的时候,我图了个省事,把php的扩展全都打开啦(就是把php.ini 那一片 extension 前面的冒号全去掉啦),这样自然有好处,以后不用再需要什么功能再来打开。 爱上php,他也会爱上你。 使用zendstdio 写代码的的时候,把tab 的缩进设置成4个空格是很有必要的 小鸟是第一次发帖(我习惯潜水的(*^__^*) 嘻嘻……),有错误之处还请大家批评指正,另外,前些日子听人说有高手能用php写驱动程序,真是学无止境,人外有人,天外有天。 我还是强烈建议自己搭建php环境。因为在搭建的过程中你会遇到一些问题,通过搜索或是看php手册解决问题后,你会更加深刻的理解它们的工作原理,了解到php配置文件中的一些选项设置。 最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。 如果你可以写完像留言板这样的程序,那么你可以去一些别人的代码了, 学好程序语言,多些才是王道,写两个小时代码的作用绝对超过看一天书,这个我是深有体会(顺便还能练打字速度)。 找到的的资料很多都是在论坛里的,需要注册,所以我一般没到一个论坛都注册一个id,所有的id都注册成一样的,这样下次再进来的时候就不用重复注册啦。当然有些论坛的某些资料是需要的付费的。 刚开始安装php的时候,我图了个省事,把php的扩展全都打开啦(就是把php.ini 那一片 extension 前面的冒号全去掉啦),这样自然有好处,以后不用再需要什么功能再来打开。 我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。 做为1门年轻的语言,php一直很努力。 开发工具也会慢慢的更专业,每个公司的可能不一样,但是zend studio是个大伙都会用的。 基础有没有对学习php没有太大区别,关键是兴趣。 我要在声明一下:我是个菜鸟!!我对php这门优秀的语言也是知之甚少。但是我要在这里说一下php在网站开发中最常用的几个功能: 在我安装pear包的时候老是提示,缺少某某文件,才发现 那群extension 的排列是应该有一点的顺序,而我安装的版本的排序不是正常的排序。没办法我只好把那群冒号加了上去,只留下我需要使用的扩展。 写的比较杂,因为我也是个新手,不当至于大家多多指正。 我学习了一段时间后,我发现效果并不好(估计是我自身的问题)。因为一个人的精力总是有限的,同时学习这么多,会导致每个的学习时间都得不到保证。
页:
[1]