程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 分享常見的幾種頁面靜態化的方法,分享幾種頁面靜態

分享常見的幾種頁面靜態化的方法,分享幾種頁面靜態

編輯:關於PHP編程

分享常見的幾種頁面靜態化的方法,分享幾種頁面靜態


什麼是PHP靜態化

PHP靜態化的簡單理解就是使網站生成頁面以靜態HTML的形式展現在訪客面前,PHP靜態化分純靜態化和偽靜態化,兩者的區別在於PHP生成靜態頁面的處理機制不同。

為什麼要讓網頁靜態化

一、加快頁面打開浏覽速度,靜態頁面無需連接數據庫打開速度較動態頁面有明顯提高;
二、有利於搜索引擎優化SEO,Baidu、Google都會優先收錄靜態頁面,不僅被收錄的快還收錄的全;
三、減輕服務器負擔,浏覽網頁無需調用系統數據庫;
四、網站更安全,HTML頁面不會受php相關漏洞的影響; 觀看一下大一點的網站基本全是靜態頁面,而且可以減少攻擊,防sql注入。

數據庫出錯時,不影響網站正常訪問。
生成html文章雖操作上麻煩些,程序上繁雜些,但為了更利於搜索,為了速度更快些,更安全,這些犧牲還是值得的。

PHP生成靜態HTML頁面的方法

利用PHP模板生成靜態頁面

PHP模板實現靜態化非常方便,比如安裝和使用PHP Smarty實現網站靜態化,也可以自己寫一套模板解析規則,常見的可以模仿各類cms的模板規則。

1.使用PHP文件讀寫功能與ob緩存機制生成靜態頁面
比如某個商品的動態詳情頁地址是: http://xxx.com?goods.php?gid=112
那麼這裡我們根據這個地址讀取一次這個詳情頁的內容,然後保存為靜態頁,下次有人訪問這個商品詳情頁動態地址時,我們可以
直接把已生成好的對應靜態內容文件輸出出來。

time()){//如果沒過期
	  echo file_get_contents($goods_statis_file);//輸出靜態文件內容
		 exit;
	 }else{//如果已過期
		 unlink($goods_statis_file);//刪除過期的靜態頁文件
		 ob_start();
 
			//從數據庫讀取數據,並賦值給相關變量
 
			//include ("xxx.html");//加載對應的商品詳情頁模板
 
			$content = ob_get_contents();//把詳情頁內容賦值給$content變量
			file_put_contents($goods_statis_file,$content);//寫入內容到對應靜態文件中
			ob_end_flush();//輸出商品詳情頁信息
	 }
}else{
 ob_start();
 
 //從數據庫讀取數據,並賦值給相關變量
 
 //include ("xxx.html");//加載對應的商品詳情頁模板
 
 $content = ob_get_contents();//把詳情頁內容賦值給$content變量
 file_put_contents($goods_statis_file,$content);//寫入內容到對應靜態文件中
 ob_end_flush();//輸出商品詳情頁信息
 
}
 
?>

2.使用nosql從內存中讀取內容(其實這個已經不算靜態化了而是緩存);

以memcache為例:


connect('memcache_host', 11211);
 
$mem_goods_content = $mem->get($goods_statis_content);
 
 
 
if($mem_goods_content){
  echo $mem_goods_content;
}else{
 ob_start();
 
 //從數據庫讀取數據,並賦值給相關變量
 
 //include ("xxx.html");//加載對應的商品詳情頁模板
 
 $content = ob_get_contents();//把詳情頁內容賦值給$content變量
 $mem->add($goods_statis_content,$content, false, $expr);
 ob_end_flush();//輸出商品詳情頁信息
 
}
 
?>

memcached是鍵值一一對應,key默認最大不能超過128個字節,value默認大小是1M,因此1M大小滿足大多數網頁大小的存儲。
以上就是頁面靜態化的相關方法,希望對朋友們有所幫助

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved