首頁 > 後端開發 > php教程 > 解析php如何利用ob快取機制實作頁面靜態化解決方案

解析php如何利用ob快取機制實作頁面靜態化解決方案

巴扎黑
發布: 2023-03-13 21:08:02
原創
1484 人瀏覽過

將PHP的執行頁面預先轉換成HTML,是所謂的PHP靜態化方法之一。

其他還有模板替換法,opcache等方法。

靜態化的作用:

提高網站的回應速度,降低伺服器的負載;
用於搜尋引擎的SEO;
利用PHP輸出buffer直接寫成html,定時後台定時掃一次網站,是比較容易實現的網頁靜態化。

靜態化之前:

for($i=0;$i<1000;$i++){

# echo "bull
";

}

?>

   

靜態化:

ob_start();

for($i=0;$i<1000;$i++){

 echo "bull< ;br>";

}

$str = ob_get_contents();

ob_end_clean();

$fp = fopen("test.html ","w");

fwrite($fp,$str);

fclose($fp);

echo "

success write";

?>

   

該段程式碼就會預先形成一個test.html,說白了其實就是用空間換取時間,像新聞類網站,發布的內容基本上寫完是不會變了,比較適合靜態化成html。

使用者造訪的時候就可以direct到這個html頁面就可以了。




首先介紹一下php

中ob快取常用到的幾個常用函數

ob_start():開啟快取機制

ob_get_contents():取得ob快取中的內容

ob_clean()清除ob快取中的內容,但不關閉快取

ob_end_clean() 清除ob快取中的內容,並關閉緩存

ob_flush 清空緩存,輸出內容,但不關閉緩存

ob_end_flush 清空緩存,輸出內容,並關閉緩存

#flush強制刷新輸出快取中的內容

依照http協定的規定,回應內容不能在回應頭之前輸出,所以,如果在header()函數前面有內容輸出,就會出現錯誤,但使用了ob_start()後就會將回應內容先放在ob快取中,不會再訊息頭發送之前被發送,就解決了header()報錯的問題!

下面說一下用php自帶的ob快取機制實作頁面靜態化的方法

#程式碼學堂php

 1 <?php 2     3     $id=$_REQUEST[&#39;id&#39;]; 4       5     //判断缓存文件是否存在,如果存在,直接输出 6     if(file_exists(&#39;content&#39;.$id.&#39;.html&#39;)){ 7       echo file_get_contents(&#39;content&#39;.$id.&#39;.html&#39;); 8       return; 9     }10      11     //开启缓存机制12     ob_start();13      14     //到数据库中查询所需要的内容15     $conn=mysql_connect("localhost","root","root");16     mysql_select(&#39;db&#39;);17     mysql_query(&#39;set names utf8&#39;);18      19     $sql="select content from table_name where id=$id";20     $res=mysql_query($sql);21     $row=mysql_fetch_assoc($res);22     $content=$row[0];23      24     mysql_free_result($res);25     mysql_close($conn);26     echo $content;27     //将输出的内容保存到文件中,形成静态页面,在下次访问的时候,直接读取输出28     file_put_contents(&#39;content&#39;.$id.&#39;.html&#39;,ob_get_contents());29  30  31 ?>
登入後複製

 

 

如上述程式碼所示:

將我們查詢到的內容直接儲存到html檔案中,如果檔案存在,之間輸出,如果不存在,則存取資料庫,執行對應的查詢過程######如果要設定檔案的過期時間,可以在if語句裡面加一個判斷條件,用於判斷快取檔案是否過期,time()-設定的過期時間# ##

以上是解析php如何利用ob快取機制實作頁面靜態化解決方案的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板