标签:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>demo</title> </head> <body> <p style="color: #ff9000;">%demo%</p> </body> </html>
这是需要替换的页面
PHP页面的静态化很有必要,尤其是在CMS系统中,一些内容一旦生成,基本上不会有变化,这时如果用html将页面静态化,无疑会减少服务其解析PHP页面的负担。以下是看书学来的PHP静态化技术,记录之以备不时之需。
无论是利用框架还是简单的脚本,原理基本一致:就是利用PHP进行文件操作,替换html模板中的动态元素,不仅能提高用户的访问速度还能让php与html分离,使代码更具有维护性。
用到的文件操作函数:
fopen() -------------------- 打开一个文件 函数有两个参数: 1.打开文件的路径和文件名 2.打开文件所用的模式(字符串形式) 这里用到了r 和 w r代表只读 w代表只写
feof() -------------------- 读取文件直到文件末尾 这个函数会在读取到文件的末尾返回true 那么就可以用while知道何时读完文件;函数有一个参数,1.打开的文件指针
fwiter() -------------------- 写入文件内容,函数有三个参数:1.写入的文件名称 2.写入的内容 3.(可选) 写入的最大字符数
fclose() ------------------------ 关闭文件;一般做完所有操作后必须关闭文件;
注意事项: 需要注意文件的路径;以及读取文件所需要的权限 ;
php代码:
<?php header("Content-type:text/html,charset=utf-8"); /******php静态化*******/ class textHtml{ public function fwriteHtml($r){ /*php页面静态化技术 *$r [array]; *route=>生成文件名称及路径 *html=>需要读取的静态资源 *stsyem=>要替换的标签 *content=>标签替换的内容 * */ $cfill = fopen($r["html"],"r");//读取的文件名 $cfillnew = fopen($r["route"],"w"); while(!feof($cfill)){ $row = fgets($cfill);
$res = str_replace($r["stsyem"],$r["content"],$row); //替换内容
fwrite($cfillnew,$res);//写入html文件 } /*关闭文件*/ fclose($cfill); fclose($cfillnew); } } $f = new textHtml; $fillname = microtime().".html"; $content = "这是一个页面静态化技术"; $r["route"] = $fillname; $r["html"] = "index.html"; $r["stsyem"] = "%demo%"; $r["content"] = $content; $f->fwriteHtml($r); ?>
最后得到的结果:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>全国城市三级联动</title> </head> <body> <p style="color: #ff9000;">这是一个页面静态化技术</p> </body> </html>
利用php静态化技术可以更好的实现网页功能 ; 在创建文章或者一些不经常改变内容中都可以用到;
标签:
原文地址:http://www.cnblogs.com/ztfjs/p/5383734.html