用PHP程序?qū)崿F(xiàn)支持頁(yè)面后退的兩種方法
更新時(shí)間:2008年06月30日 09:17:00 作者:
在開發(fā)過(guò)程中,往往因?yàn)楸韱纬鲥e(cuò)而返回頁(yè)面的時(shí)候填寫的信息都不見了,為了支持頁(yè)面回跳,可以通過(guò)兩種方法實(shí)現(xiàn)。
第一,使用Header方法設(shè)置消息頭Cache-control
QUOTE:
header('Cache-control: private, must-revalidate'); //支持頁(yè)面回跳
第二,使用session_cache_limiter方法
QUOTE:
//注意要寫在session_start方法之前
session_cache_limiter('private, must-revalidate');
補(bǔ)充:
Cache-Control消息頭域說(shuō)明
Cache-Control指定請(qǐng)求和響應(yīng)遵循的緩存機(jī)制。在請(qǐng)求消息或響應(yīng)消息中設(shè)置Cache-Control并不會(huì)修改另一個(gè)消息處理過(guò)程中的緩存處理過(guò)程。請(qǐng)求時(shí)的緩存指令包括no-cache、no-store、max-age、max-stale、min-fresh、only-if- cached,響應(yīng)消息中的指令包括public、private、no-cache、no-store、no-transform、must- revalidate、proxy-revalidate、max-age。各個(gè)消息中的指令含義如下:
Public指示響應(yīng)可被任何緩存區(qū)緩存。
Private指示對(duì)于單個(gè)用戶的整個(gè)或部分響應(yīng)消息,不能被共享緩存處理。這允許服務(wù)器僅僅描述當(dāng)用戶的部分響應(yīng)消息,此響應(yīng)消息對(duì)于其他用戶的請(qǐng)求無(wú)效。
no-cache指示請(qǐng)求或響應(yīng)消息不能緩存
no-store用于防止重要的信息被無(wú)意的發(fā)布。在請(qǐng)求消息中發(fā)送將使得請(qǐng)求和響應(yīng)消息都不使用緩存。
max-age指示客戶機(jī)可以接收生存期不大于指定時(shí)間(以秒為單位)的響應(yīng)。
min-fresh指示客戶機(jī)可以接收響應(yīng)時(shí)間小于當(dāng)前時(shí)間加上指定時(shí)間的響應(yīng)。
max-stale指示客戶機(jī)可以接收超出超時(shí)期間的響應(yīng)消息。如果指定max-stale消息的值,那么客戶機(jī)可以接收超出超時(shí)期指定值之內(nèi)的響應(yīng)消息。
關(guān)于表單刷新
問(wèn):為什么我在點(diǎn)擊瀏覽器的后退按鈕后,所有字段的信息都被清空了?
答:這是由于你在你的表單提交頁(yè)面中使用了 session_start 函數(shù)。該函數(shù)會(huì)強(qiáng)制當(dāng)前頁(yè)面不被緩存。解決辦法為,在你的 Session_start 函數(shù)后加入 header("Cache-control: private"); 注意在本行之前你的PHP程序不能有任何輸出。
補(bǔ)充:還有基于session的解決方法,在session_start前加上
QUOTE:
session_cache_limiter('nocache');// 清空表單
session_cache_limiter('private'); //不清空表單,只在session生效期間
session_cache_limiter('public'); //不清空表單,如同沒(méi)使用session一般
可以在session_start();前加上 session_cache_limiter("private,max-age=10800");
QUOTE:
header('Cache-control: private, must-revalidate'); //支持頁(yè)面回跳
第二,使用session_cache_limiter方法
QUOTE:
//注意要寫在session_start方法之前
session_cache_limiter('private, must-revalidate');
補(bǔ)充:
Cache-Control消息頭域說(shuō)明
Cache-Control指定請(qǐng)求和響應(yīng)遵循的緩存機(jī)制。在請(qǐng)求消息或響應(yīng)消息中設(shè)置Cache-Control并不會(huì)修改另一個(gè)消息處理過(guò)程中的緩存處理過(guò)程。請(qǐng)求時(shí)的緩存指令包括no-cache、no-store、max-age、max-stale、min-fresh、only-if- cached,響應(yīng)消息中的指令包括public、private、no-cache、no-store、no-transform、must- revalidate、proxy-revalidate、max-age。各個(gè)消息中的指令含義如下:
Public指示響應(yīng)可被任何緩存區(qū)緩存。
Private指示對(duì)于單個(gè)用戶的整個(gè)或部分響應(yīng)消息,不能被共享緩存處理。這允許服務(wù)器僅僅描述當(dāng)用戶的部分響應(yīng)消息,此響應(yīng)消息對(duì)于其他用戶的請(qǐng)求無(wú)效。
no-cache指示請(qǐng)求或響應(yīng)消息不能緩存
no-store用于防止重要的信息被無(wú)意的發(fā)布。在請(qǐng)求消息中發(fā)送將使得請(qǐng)求和響應(yīng)消息都不使用緩存。
max-age指示客戶機(jī)可以接收生存期不大于指定時(shí)間(以秒為單位)的響應(yīng)。
min-fresh指示客戶機(jī)可以接收響應(yīng)時(shí)間小于當(dāng)前時(shí)間加上指定時(shí)間的響應(yīng)。
max-stale指示客戶機(jī)可以接收超出超時(shí)期間的響應(yīng)消息。如果指定max-stale消息的值,那么客戶機(jī)可以接收超出超時(shí)期指定值之內(nèi)的響應(yīng)消息。
關(guān)于表單刷新
問(wèn):為什么我在點(diǎn)擊瀏覽器的后退按鈕后,所有字段的信息都被清空了?
答:這是由于你在你的表單提交頁(yè)面中使用了 session_start 函數(shù)。該函數(shù)會(huì)強(qiáng)制當(dāng)前頁(yè)面不被緩存。解決辦法為,在你的 Session_start 函數(shù)后加入 header("Cache-control: private"); 注意在本行之前你的PHP程序不能有任何輸出。
補(bǔ)充:還有基于session的解決方法,在session_start前加上
QUOTE:
session_cache_limiter('nocache');// 清空表單
session_cache_limiter('private'); //不清空表單,只在session生效期間
session_cache_limiter('public'); //不清空表單,如同沒(méi)使用session一般
可以在session_start();前加上 session_cache_limiter("private,max-age=10800");
相關(guān)文章
PHP實(shí)現(xiàn)數(shù)據(jù)庫(kù)統(tǒng)計(jì)時(shí)間戳按天分組輸出數(shù)據(jù)的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)數(shù)據(jù)庫(kù)統(tǒng)計(jì)時(shí)間戳按天分組輸出數(shù)據(jù)的方法,涉及php基于時(shí)間的運(yùn)算與數(shù)據(jù)庫(kù)查詢相關(guān)操作技巧,需要的朋友可以參考下2017-10-10PHP同時(shí)連接多個(gè)mysql數(shù)據(jù)庫(kù)示例代碼
這篇文章主要介紹了PHP同時(shí)連接多個(gè)mysql數(shù)據(jù)庫(kù)的具體實(shí)現(xiàn),需要的朋友可以參考下2014-03-03PHP+Mysql實(shí)現(xiàn)多關(guān)鍵字與多字段生成SQL語(yǔ)句的函數(shù)
這篇文章主要介紹了PHP+Mysql實(shí)現(xiàn)多關(guān)鍵字與多字段生成SQL語(yǔ)句的函數(shù),涉及字符串與數(shù)組的操作,是構(gòu)造SQL語(yǔ)句非常實(shí)用的技巧,需要的朋友可以參考下2014-11-11