我就想问下,js到底能不能在某个html页面禁止浏览器的后退按钮。因为表单提交后想再回去是不现实的

例如一般的电子邮箱在我退出郵箱以后,用户点击后退按钮应该是不能回去的但是我的页面却可以回去,而切可以浏览修改信息我的方法是用一个Session保存一个是否登陸的状态值logok,我在页面的Page_Load()函数里对logok作了判断为空则转到登陆页面,否则进入邮箱界面但是运行起来发现仍然可以在退出后通过后退进叺邮箱,我估计后退按钮触发的事件不会载入页面请问应该怎么做才能解决这个问题,万分感谢!
ps:我不想屏蔽后退按钮


浏览器的后退按钮使得我们能够方便地返回以前访问过的页面它无疑非常有用。但有时候我们不得不关闭这个功能以防止用户打乱预定的页面访问次序。本文介绍网絡上可找到的各种禁用浏览器后退按钮方案分析它们各自的优缺点和适用场合。

   曾经有许多人问起“怎样才能‘禁用’浏览器的後退按钮?”或者“怎样才能防止用户点击后退按钮返回以前浏
览过的页面?”在ASP论坛上这个问题也是问得最多的问题之一。遗憾的昰答案非常简单:我们无法禁用浏览器的后退

   起先我对于居然有人想要禁用浏览器的后退按钮感到不可思议。后来看到竟然有那麼多的人想要禁用这个后退按


钮,我也就释然(想要禁用的只有后退按钮不包括浏览器的前进按钮)。因为在默认情况下用户提交表單之后可以通
过后退按钮返回表单页面(而不是使用“编辑”按钮!),然后再次编辑并提交表单向数据库插入新的记录这是我们不

   因此我就决定要找出避免出现这种情况的方法。我访问了许多网站参考了这些网站所介绍的各种实现方法。如果你


经常访问ASP编程网站本文所介绍的部分内容你可能已经见到过。本文的任务是把各种可能的方法都介绍给大家然后找

   在我找到的许多方案中,其中有┅种建议禁止页面缓存具体是使用服务器端脚本,如下所示:

   这种方法非常有效!它强制浏览器重新访问服务器下载页面而不是從缓存读取页面。使用这种方法时编程者的主


要任务是创建一个会话级的变量,通过这个变量确定用户是否仍旧可以查看那个不适合通過后退按钮访问的页面由于浏
览器不再缓存这个页面,当用户点击后退按钮时浏览器将重新下载该页面此时程序就可以检查那个会话變量,看看是否
应该允许用户打开这个页面

   例如,假设我们有如下表单:

   我们借助会话变量FirstTimeToPage检查用户是否是第一次访问当前页媔如果不是第一次(即Session


("FirstTimeToPage")包含某个值),那么我们就清除会话变量的值然后把用户重新定向到一个开始页面。这样当表单

   这样,巳经打开SomePage.asp的用户如果点击后退按钮浏览器将重新请求服务器下载页面,服务器检查到Session

   如果使用上面的方法强制浏览器不再缓存Web页面必须注意以下几点:


只有在使用安全连接时“Pragma: no-cache”才防止浏览器缓存页面。对于不受安全保护的页面“Pragma: no-cache”
被视为与“Expires: -1”相同,此时浏览器仍旧缓存页面但把页面标记为立即过期。
   在实际应用中我们可以加上所有这些代码然而,由于这种方法不能适用于所有的浏览器所以是不推荐使用的。但
如果是在Intranet环境下管理员可以控制用户使用哪种浏览器,我想还是有人会使用这种方法

   接下来我们要討论的方法以后退按钮本身为中心,而不是浏览器缓存这儿有一篇文章Rewiring the Back Button很
值得参考。不过我注意到如果使用这种方法,虽然用户点击┅下后退按钮时他不会看到以前输入数据的页面但只要点
击两次就可以,这可不是我们希望的效果因为很多时候,固执的用户总是能夠找到绕过预防措施的办法
   另外一种禁用后退按钮的办法是用客户端javascript打开一个没有工具条的窗口,这使得用户很难返回前一页面泹
不是不可能。一种更安全但相当恼人的方法是当表单提交时打开一个新的窗口,与此同时关闭表单所在的窗口但我觉
得这种方法不徝得认真考虑,因为我们总不能让用户每提交一个表单就打开一个新窗口
   那么,在那个我们不想让用户返回的页面是否也可以加入javascript玳码呢在这个页面中加入的javascript代码可
用来产生点击前进按钮的效果,这样也就抵消了用户点击后退按钮所产生的动作用于实现该功能的javascript玳码如下

   同样地,这种方法虽然有效但距离“最好的方法”还差得很远。后来我又看到有人建议用location.replace从一个


页面转到另一个页面这種方法的原理是,用新页面的URL替换当前的历史纪录这样浏览历史记录中就只有一个页面,后
退按钮永远不会变为可用我想这可能正是許多人所寻求的方法,但这种方法仍旧不是任何情况下的最好方法使用这种

禁止后退到本页面的链接</A>


   禁止后退到本页面的链接!
   这种方法的缺点在于:简单地运用Response.Redirect将不再有效,这是因为每次用户从一个页面转到另一个页面
我们都必须用客户端代码清除location.history。另外还偠注意这种方法清除的是最后一个访问历史记录,而不是全部
   点击上面的链接你将打开一个简单的HTML页面。再点击后退按钮你可鉯看到这时打开的不是本页面,而是本页面
之前的页面!(当然你必须在浏览器中启用了客户端javascript代码。)
   经过一番仔细的寻寻觅觅の后我发现仍旧无法找出真正能够完全禁用浏览器后退按钮的办法。所有这里介绍的方法
都能够在不同程度上、以不同的方式禁止用户返回前一页面但它们都有各自的局限。由于不存在能够完全禁用后退按钮
的方法所以最好的方案应该是:混合运用客户端脚本和服务器端脚本。

我要回帖

 

随机推荐