註冊
登錄
首頁
論壇版規
禁止列表
說明
地圖
數位書香
私人消息 (0)
公共消息 (0)
論壇任務 (0)
系統消息 (0)
好友消息 (0)
帖子消息 (0)
麻辣家族討論版版
»
PHP
» (PHP+IIS+MsSQL教學第16篇) 資料的讀取與輸出 下篇
返回列表
下一主題
上一主題
發帖
[教學]
(PHP+IIS+MsSQL教學第16篇) 資料的讀取與輸出 下篇
小誌
發短消息
加為好友
小誌
(小誌)
當前離線
曾經也是水電工
UID
9
帖子
1195
主題
395
精華
113
積分
1747
金錢
1747
點名
0
作業系統
Vista
軟體版本
Office 2003
閱讀權限
200
性別
男
來自
台灣
在線時間
491 小時
註冊時間
2010-5-1
最後登錄
2025-5-11
暱稱:
小誌
頭銜:
曾經也是水電工
管理員
帖子
1195
主題
395
精華
113
積分
1747
點名
0
作業系統
Vista
軟體版本
Office 2003
閱讀權限
200
性別
男
來自
台灣
註冊時間
2010-5-1
最後登錄
2025-5-11
1
#
跳轉到
»
倒序看帖
打印
字體大小:
t
T
發表於 2010-5-14 17:51
|
只看該作者
[教學]
(PHP+IIS+MsSQL教學第16篇) 資料的讀取與輸出 下篇
IIS
,
下篇
,
MsSQL
,
PHP
緩衝區的使用
通常,在我們下達輸出命令時,網頁伺服器便將資料立即送交客戶端的瀏覽器,此時,
PHP
程式並不一定是已經執行完畢了,因此,網頁伺服器可能是一邊在執行敘述命令,另一邊又在忙著輸出資料,所以造成網頁伺服器的負載較重,為了改善這種情形,可以呼叫「ob_start()」
函數
,讓要輸出到客戶端瀏覽器的資料先寫入到「buffer(緩衝區)」裡,等到PHP程式執行完畢,也就是整個PHP網頁都解譯完畢,再將存放在緩衝區裡的資料一併(全部的資料)輸出到客戶端瀏覽器。
在之前範例的說明中,筆者強調header()函數只可用在尚未有任何資料輸出至瀏覽器之前才可呼叫,否則將會產生錯誤:「已將 HTTP 標頭寫入用戶端瀏覽器」,因此,我們可呼叫「ob_start()」函數,讓整個PHP網頁都解譯完畢後,再將存放在緩衝區裡的資料一併全部地輸出到客戶端瀏覽器:
<html><body>
<?
ob_start();
header("Location: message.htm");
?>
</body>
</html>
複製
代碼
喔喔!還是錯了,因為上例的HEML標籤(<html><body>)放置在「ob_start();」命令敘述之前,HEML標籤已早一步執行輸出的動作了,所以,「ob_start();」命令敘述應該擺在任何HEML標籤或header()函數、echo()、print()函數、printf()函數命令敘述之前,最簡單的方法就是將「ob_start();」命令敘述放在PHP程式網頁的第一行,更改如下:
<? ob_start();?>
<html><body>
<?
header("Location: message.htm");
?>
</body>
</html>
複製代碼
強制輸出與清除緩衝區資料
當我們執行「ob_start();」命令敘述後,也就是開啟緩衝區後,並不一定要等到整份PHP網頁都解譯完畢後才能開始輸出資料,在PHP網頁解譯的過程中,我們可以利用flush()函數強制將存放於緩衝區的資料立即輸出,也可以利用ob_end_flush()函數將存放於緩衝區的資料輸出並關閉緩衝區。
<? ob_start();?>
<html><body>
<?
echo "資料第一次存入緩衝區";
ob_end_flush();
ob_start();
echo "資料第二次存入緩衝區";
ob_end_clean();
?>
</body>
</html>
複製代碼
以上例來說,輸出的資料將只有被強制輸出的「<html>、<body>」與「資料第一次存入緩衝區」,還有整份PHP網頁都解譯完畢才開始輸出的資料「</html>、</body>」。
在「<html>、<body>」與「資料第一次存入緩衝區」在ob_end_flush()命令執行後被強制輸出,而緩衝區也同時被關閉了。
當執行「echo "資料第二次存入緩衝區";」命令敘述後,『資料第二次存入緩衝區』被存放至緩衝區。
「ob_end_clean();」命令敘述執行後,緩衝區內容被清除,『資料第二次存入緩衝區』被人間蒸發不存在了!而緩衝區也再次被關閉了。
「</html>、</body>」並沒有被存放至緩衝區,而是被直接輸出。
以上論證可藉由範例執行後,從檢視網頁原始檔中獲得證明,如下圖:
下載
(28.3 KB)
2010-5-14 17:50
樓主熱帖
論壇不讓資歷比較淺的人下載查看附件的用意
EXCEL專屬討論區自即日起限中學生以上會員方
麻辣家族討論區 通用版規
OFFICE 基礎教學數位化
ATX 電源供應器手動啟動(不接主機板啟動)
考慮關閉論壇網站
麻辣家族討論區隱私權政策說明
麻辣家族討論區 誠徵版主
由舊論壇轉進的中學生等級以上會員,請關注!
14-2 資料庫圖片存取
收藏
分享
心安,平安
發表任何無意義的感謝或灌水文章一律砍,珍惜帳號,請詳閱版規!!
靜思自在 :
是非當教育,讚美作警惕。
返回列表
下一主題
上一主題
EXCEL專屬討論區
Excelㄧ般區
Excel程式區
進階應用專區
OFFICE 系列
Word
PowerPoint
Access
Office不分區
程式語言
VB 與 VB.Net
C 與 C#
Java 與 J#
程式設計不分區
資料庫
ORACLE
My SQL
MS SQL
網頁設計
ASP 與 ASP.NET
PHP
PHP+MySQL 入門實作
JavaScript
FLASH / ActionScript
HTM/ HTML/ CSS
網頁設計不分區
電腦與作業系統
電腦各種硬體討論
一般電腦軟體討論
論壇事務
管理公告
投訴反映
新手測試
愛 ‧ 生活
公益佈告欄
生活與感動
[收藏此主題]
[關注此主題的新回復]
[通過 QQ、MSN 分享給朋友]
申請友情鏈接
Facebook粉絲