快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

用ASP实现禁用浏览器的后退按钮

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

一、概述

曾经有许多人问起,“怎样才能‘禁用’浏览器的后退按钮?”,或者“怎样才能防止用户点击后退按钮返回以前浏览过的页面?”我访问了许多网站,参考了这些网站所介绍的各种实现方式。假如你常常访问ASP编程网站,本文所介绍的部分内容你可能已经见到过。本文的任务是把各种可能的方式都介绍给大家,然后找出最好的方式!

二、禁止缓存

在我找到的许多方案中,其中有一种建议禁止页面缓存。详细是使用服务器端脚本,如下所示:
<%
Response.Buffer = True
Response.ExpiresAbsolute = Now() - 1
Response.Expires = 0
Response.CacheControl = "no-cache"
%>

这种方式异常有效!它强制浏览器重新访问服务器下载页面,而不是从缓存读取页面。使用这种方式时,编程者的主要任务是创建一个会话级的变量,通过这个变量确定用户是否仍然可以查看那个不适合通过后退按钮访问的页面。由于浏览器不再缓存这个页面,当用户点击后退按钮时浏览器将重新下载该页面,此时程序就可以检查那个会话变量,看看是否应该答应用户打开这个页面。

例如,假设我们有如下表单:
<%
Response.Buffer = True
Response.ExpiresAbsolute = Now() - 1
Response.Expires = 0
Response.CacheControl = "no-cache"
If Len(Session("FirstTimeToPage")) > 0 then
"用户已经访问过当前页面,现在是再次返回访问。
"清除会话变量,将用户重定向到登录页面。
Session("FirstTimeToPage") = ""
Response.Redirect "/Bar.asp"
Response.End
End If
"假如程序运行到这里,说明用户能够查看当前页面
"以下开始创建表单
%>
<form method=post action="SomePage.asp">
<input type=submit>
</form>

  我们借助会话变量FirstTimeToPage检查用户是否是第一次访问当前页面。假如不是第一次(即Session("FirstTimeToPage")包含某个值),那么我们就清除会话变量的值,然后把用户重新定向到一个开始页面。这样,当表单提交时(此时SompePage.asp被打开),我们必须赋予FirstTimeToPage一个值。即,在 SomePage.asp中我们需要加上下面的代码:

Session("FirstTimeToPage") = "NO"

这样,已经打开SomePage.asp的用户假如点击后退按钮,浏览器将重新哀求服务器下载页面,服务器检查到Session("FirstTimeToPage")包含了一个值,于是就清除Session ("FirstTimeToPage"),并把用户重定向到其他页面。当然,所有这一切都需要用户启用了Cookie,否则会话变量将是无效的。

另外,我们也可以用客户端代码使浏览器不再缓存Web页面:

<html>
<head>
<meta http-equiv="Expires" CONTENT="0">
<meta http-equiv="Cache-Control" CONTENT="no-cache">
<meta http-equiv="Pragma" CONTENT="no-cache">
</head>

假如使用上面的方式强制浏览器不再缓存Web页面,必须注重以下几点:

只有在使用安全连接时“Pragma: no-cache”才防止浏览器缓存页面。对于不受安全保护的页面,“Pragma: no-cache”被视为与“Expires: -1”一样,此时浏览器仍然缓存页面,但把页面标记为立刻过期。

在IE 4或5中,“Cache-Control”META HTTP-EQUIV标记将被忽略,不起作用。

在实际应用中我们可以加上所有这些代码。然而,由于这种方式不能适用于所有的浏览器,所以是不推荐使用的。但假如是在Intranet环境下,治理员可以控制用户使用哪种浏览器,我想还是有人会使用这种方式。

三、其他方式

  接下来我们要讨论的方式以后退按钮本身为中央,而不是浏览器缓存。这儿有一篇文章Rewiring the Back Button很值得参考。不过我注重到,假如使用这种方式,虽然用户点击一下后退按钮时他不会看到以前输入数据的页面,但只要点击两次就可以,这可不是我们希望的效果,因为很多时候,固执的用户总是能够找到绕过防备措施的办法。

  另外一种禁用后退按钮的办法是用客户端JavaScript打开一个没有工具条的窗口,这使得用户很难返回前一页面,但不是不可能。一种更安全但相称恼人的方式是,当表单提交时打开一个新的窗口,与此同时关闭表单所在的窗口。但我觉得这种方式不值得认真考虑,因为我们总不能让用户每提交一个表单就打开一个新窗口。

那么,在那个我们不想让用户返回的页面是否也可以加入JavaScript代码呢?在这个页面中加入的JavaScript代码可用来产生点击前进按钮的效果,这样也就抵消了用户点击后退按钮所产生的动作。用于实现该功能的JavaScript代码如下所示:

<script language="JavaScript">
<!--
javascript:window.history.forward(1);
//-->
</script>

同样地,这种方式虽然有效,但距离“最好的方式”还差得很远。后来我又看到有人建议用location.replace从一个页面转到另一个页面。这种方式的原理是,用新页面的URL替换当前的历史纪录,这样浏览历史记录中就只有一个页面,后退按钮永远不会变为可用。我想这可能正是许多人所寻求的方式,但这种方式仍然不是任何情况下的最好方式。使用这种方式的实例如下所示:

<A HREF="PageName.htm" onclick="javascript:location.replace(this.href); event.returnValue=false; ">

禁止后退到本页面的链接

试试下面这个链接:

禁止后退到本页面的链接!

这种方式的缺点在于:简朴地运用Response.Redirect将不再有效,这是因为每次用户从一个页面转到另一个页面,我们都必须用客户端代码清除location.history。另外还要注重,这种方式清除的是最后一个访问历史记录,而不是全部的访问记录。

点击上面的链接,你将打开一个简朴的HTML页面。再点击后退按钮,你可以看到这时打开的不是本页面,而是本页面之前的页面!(当然,你必须在浏览器中启用了客户端JavaScript代码。)

经过一番仔细的寻寻觅觅之后,我发现仍然无法找出真正能够完全禁用浏览器后退按钮的办法。所有这里介绍的方式都能够在不同程度上、以不同的方法禁止用户返回前一页面,但它们都有各自的局限。由于不存在能够完全禁用后退按钮的方式,所以最好的方案应该是:混合运用客户端脚本和服务器端脚本。
返回类别: 教程
上一教程: ASP:留言簿自动发E-MAIL
下一教程: 用ASP、VB和XML建立互联网应用程序(2)

您可以阅读与"用ASP实现禁用浏览器的后退按钮"相关的教程:
· 全面考察“禁用浏览器后退按钮”
· 关于“禁用浏览器后退按钮”
· 用ASP开发基于浏览器的文档数据库治理软件
· ASP: 浏览器中上载文件的方式与实现
· 利用ASP实现对表的分页浏览(上)
    微笑服务 优质保证 索取样品