防止使用者按上一頁按鈕
討論區上常有網友問到這個問題, 如何防止使用者按回上一頁按鈕, 為何會問這一個問題? 應該通常是在防止使用者重複執行一個應用程式, 例如資料庫的新增, 如果使用者按了回上一頁, 有可能會造成重複新增資料, 今天這篇文章就要介紹如何 "盡可能" 的防止使用者按回上一頁
伺服端防止快取
首先來看看伺服端的方法, asp 的 response 物件提供了幾個網頁快取 (cache) 相關的屬性, 說明如下
屬性 說明
cachecontrol 判斷代理伺服器 (proxy server) 是否快取 asp 的輸出結果
expires 網頁快取的逾期時間
expiresabsolute 指定網頁快取的逾期時間
所以如果你要防止網頁被快取, 你可以這麼做
<%
response.buffer = true
response.expiresabsolute = now() – 1
response.expires = 0
response.cachecontrol = "no-cache"
%>
利用這個方法, 使用者還是可以回到上一頁, 但由於網頁並沒有被快取, 所以瀏覽器必須重新向伺服器作 http 請求, 也就是這個網頁會被重新整理 (refresh)
用戶端防止快取
你也可以使用用戶端 (client-side) 的方式,
<html>
<head>
<meta http-equiv="expires" content="0">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="pragma" content="no-cache">
</head>
和伺服端的方法產生的結果是一樣的, 但有幾點要注意
pragma : 當使用安全連結時才使用 pragma, 如果在非安全連結使用, 那麼效果和 expires : -1 是相同的, 也就是這個網頁還是會被快取, 但會立即逾時
meta http-equiv 標籤的 cache-control 並不適用於 internet explorer 4, 5 版本
移除工具列
這個方法是在網路上看來的, 有點趣味所以也介紹一下, 做法是這樣的, 利用 window.open 方法來開新視窗, 然後關掉原視窗, 但重點是在開視窗時將工具列移除
<script language="javascript">
<!–
function openwindow(url){
newpage = window.open(url,newpage,toolbar=no);
newpage.focus();
self.close();
}
//–>
</script>
<a href="javascript:openwindow(nextpage.html);">下一頁</a>
也是一種方法, 但應該很少人會用, 有一點麻煩! 況且按滑鼠右鍵所出現的 menu 中也有回上一頁的選項, 此法謹防君子不防小人!
使用 location.replace
javascript location 物件的 replace() 方法會以指定的網址覆蓋瀏覽器目前瀏覽歷史紀錄, 也就是當你用了這個方法, 瀏覽器就會忘掉過去曾經瀏覽的紀錄, 就親像你第一次開啟瀏覽器一樣, 上一頁的按鈕是灰的
你可以這麼做
<a href="javascript:location.replace(nextpage.html)">下一頁</a>
看起來這大概是目前最好的方法! 不過還是有一些缺點, 因為並不是所有的情況都可以套用, 譬如講當你使用 response.redirect 時, 這個方法就派不上用場了!
可以歸納出一個結論, 就是要完全關閉瀏覽器回上一頁的功能是不可能的 (目前的瀏覽器), 唯一能做的是因時因地制宜, 結合以上的方法盡可能的防止使用者按回上一頁!
希望這篇文章對你有幫助!
