php表單在提交之後再後退,表單的內容預設是被清空的(使用session_start的時候),
解決方案是在session_start() 之後,字元輸出之前寫上
複製代碼 代碼如下:
header("Cache-control: private");
網頁的緩衝是由HTTP訊息頭中的“Cache-control”來控制的,常見的取值有private、no- cache、max-age、must-revalidate等,預設為private。其作用根據不同的重新瀏覽方式分為以下幾種情況:
(1) 開啟新視窗
值為private、no-cache、must-revalidate,那麼開啟新視窗訪問時都會重新訪問伺服器。
而如果指定了max-age值,那麼在此值內的時間裡就不會重新訪問伺服器,例如:
Cache-control: max-age=5(表示當訪問此網頁後的5秒內再次訪問不會去伺服器)
(2) 在地址欄斷行符號
值為private或must-revalidate則只有第一次訪問時會訪問伺服器,以後就不再訪問。
值為no-cache,那麼每次都會訪問。
值為max-age,則在到期之前不會重複訪問。
(3) 按後退按扭
值為private、must-revalidate、max-age,則不會重訪問,
值為no-cache,則每次都重複訪問
(4) 按重新整理按扭
無論為何值,都會重複訪問
Cache-control值為“no-cache”時,訪問此頁面不會在Internet臨時文章夾留下頁面備份。
另外,通過指定“Expires”值也會影響到緩衝。例如,指定Expires值為一個早已過去的時間,那麼訪問此網時若重複在地址欄按斷行符號,那麼每次都會重複訪問: Expires: Fri, 31 Dec 1999 16:00:00 GMT
比如:禁止頁面在 IE中緩衝
http響應訊息頭部設定:
CacheControl = no-cache
Pragma=no-cache
Expires = -1
Expires是個好東東,如果伺服器上的網頁經常變化,就把它設定為-1,表示立即到期。如果一個網頁每天淩晨1 點更新,可以把Expires設定為第二天的淩晨1點。
當HTTP1.1伺服器指定CacheControl = no-cache時,瀏覽器就不會緩衝該網頁。
舊式 HTTP 1.0 伺服器不能使用 Cache-Control 標題。
所以為了向後相容 HTTP 1.0 伺服器,IE使用Pragma:no-cache 標題對 HTTP 提供特殊支援。
如果用戶端通過安全連線 (https://)與伺服器通訊,且伺服器在響應中返回 Pragma:no-cache 標題,
則 Internet Explorer不會緩衝此響應。注意:Pragma:no-cache 僅當在安全連線中使用時才防止緩衝,如果在非安全頁中使用,處理方式與 Expires:-1相同,該頁將被緩衝,但被標記為立即到期。
Cache-Control 訊息頭域說明
Cache-Control指定請求和響應遵循的緩衝機制。在請求訊息或響應訊息中設定
Cache-Control並不會修改另一個訊息處理過程中的緩衝處理過程。請求時的緩衝指令包括no- cache、no-store、max-age、max-stale、min-fresh、only-if-cached,響應訊息中的指令包括 public、private、no-cache、no-store、no-transform、must-revalidate、proxy- revalidate、max-age。各個訊息中的指令含義如下:
Public指示響應可被任何緩衝區緩衝。
Private指示對於單個使用者的整個或部分響應訊息,不能被共用快取處理。這允許伺服器僅僅描述當使用者的部分響應訊息,此響應訊息對於其他使用者的請求無效。
no- cache指示請求或響應訊息不能緩衝
no-store用於防止重要的資訊被無意的發布。在請求訊息中發送將使得請求和響應訊息都不使用緩衝。
max- age指示客戶機可以接收生存期不大於指定時間(以秒為單位)的響應。
min-fresh指示客戶機可以接收回應時間小於目前時間加上指定時間的響應。
max-stale指示客戶機可以接收超出逾時期間的響應訊息。如果指定max-stale訊息的值,那麼客戶機可以接收超出逾時期指定值之內的響應訊息。