本篇文章給大家分享的是有關(guān)怎么在php中利用ob緩存機制對頁面進行靜態(tài)化,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

首先介紹一下php中ob緩存常用到的幾個常用函數(shù)
ob_start():開啟緩存機制
ob_get_contents():獲取ob緩存中的內(nèi)容
ob_clean()清除ob緩存中的內(nèi)容,但不關(guān)閉緩存
ob_end_clean() 清除ob緩存中的內(nèi)容,并關(guān)閉緩存
ob_flush 清空緩存,輸出內(nèi)容,但不關(guān)閉緩存
ob_end_flush 清空緩存,輸出內(nèi)容,并關(guān)閉緩存
flush強制刷新輸出緩存中的內(nèi)容
按照http協(xié)議的規(guī)定,回應內(nèi)容不能在回應頭之前輸出,所以,如果在header()函數(shù)前面有內(nèi)容輸出,就會出現(xiàn)錯誤,但使用了ob_start()后就會將回應內(nèi)容先放在ob緩存中,不會再消息頭發(fā)送之前被發(fā)送,就解決了header()報錯的問題!
下面說一下用php自帶的ob緩存機制實現(xiàn)頁面靜態(tài)化的方法,示例代碼如下
<?php
$id=$_REQUEST['id'];
//判斷緩存文件是否存在,如果存在,直接輸出
if(file_exists('content'.$id.'.html')){
echo file_get_contents('content'.$id.'.html');
return;
}
//開啟緩存機制
ob_start();
//到數(shù)據(jù)庫中查詢所需要的內(nèi)容
$conn=mysql_connect("localhost","root","root");
mysql_select('db');
mysql_query('set names utf8');
$sql="select content from table_name where id=$id";
$res=mysql_query($sql);
$row=mysql_fetch_assoc($res);
$content=$row[0];
mysql_free_result($res);
mysql_close($conn);
echo $content;
//將輸出的內(nèi)容保存到文件中,形成靜態(tài)頁面,在下次訪問的時候,直接讀取輸出
file_put_contents('content'.$id.'.html',ob_get_contents());
?>如上述代碼所示:
將我們查詢到的內(nèi)容直接保存到html文件中,如果文件存在,之間輸出,如果不存在,則訪問數(shù)據(jù)庫,執(zhí)行對應的查詢過程
如果要設置文件的過期時間,可以在if語句里面加一個判斷條件,用于判斷緩存文件是否過期,time()-設置的過期時間
以上就是怎么在php中利用ob緩存機制對頁面進行靜態(tài)化,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
名稱欄目:怎么在php中利用ob緩存機制對頁面進行靜態(tài)化-創(chuàng)新互聯(lián)
分享URL:http://www.chinadenli.net/article12/diohdc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供ChatGPT、軟件開發(fā)、網(wǎng)站改版、微信小程序、外貿(mào)建站、網(wǎng)站維護
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容