asp.net 防止用户通过后退按钮重复提交表单 -k8凯发
防止用户通过后退按钮重复提交表单
<%
response。buffer=true
response。expires=0
response。expiresabsolute=now()-1
response。
cachecontrol=”no-cache”
%>
response。buffer=true的意思就是指明输出页面是否被缓冲,当属性值为true时,服务器将不会向客户端发送任何信息,直到所有程序执行完或者遇到
<% response。
flush %>或<% response。end %>
语句,才会释放缓冲区的信息。
expires 属性
expires 属性指定了在浏览器上缓冲存储的页距过期还有多少时间。
如果用户在某个页过期之前又回到此页,就会显示缓冲区中的版本
语法
response。expires [= number]
参数
number
距过期还有多少分钟。
将此参数设置为 0 可使缓存的页立即过期。
注释
若此属性在一页上设置了多次,则使用最短的时间。
应用于
response 对象
response。
expires=0也表示立即过期,但如果client和server不在一个时区或者client的时间早于server上的时间,则不能立即过期。所以用负数或者用response。expiresabsolute=now()-1来表示立即过期,response。
expires=1表示在1分钟后过期。
asp中response。expiresabsolute=now()-1
在asp页面中,通常会有这样的设置。
response。expiresabsolute=now()-1‘设置过期时间的绝对值为当前时间-1,即出来后就过期了
这是因为默认情况下,浏览器将页面先载入缓存,然后才显示出来.通过上述设置,使浏览器对页面不进行缓存,所以当用户点"后退"后,由于页面没有缓存,所以浏览器只能再次通过向服务器发出http请求来得到页面,这样就实现了限制了用户对同一网页进行多次操作。
asp中response。expires = -1
一般情况下,当用户请求web服务器时,服务器把请求回复给客户端。在客户端,浏览器把缓存作为一种加快速度的策略,就是当请求时先检查缓存的情况,如果有就直接调缓存了,而不请求服务器了。
在web程序设计中,有时为了防止重复的提交或者严格的次序等,必须让用户的数据立即在使用后就过期,当用户后退时就显示过期而不能继续使用。也算是为安全考虑的吧。
一般,response。expires写在页面的最上端,后面跟的是一个时间,就是过期的时间,0表示立即过期。
asp中对浏览器缓存的设置
response。cachecontrol = “no-cache”
设置不缓存在临时文件中。本句是指,上网时看到的图片通常在internet的
接下来我们要讨论的方法以后退按钮本身为中心,而不是浏览器缓存。
这儿有一篇文章rewiring the back button很值得参考。不过我注意到,如果使用这种方法,虽然用户点击一下后退按钮时他不会看到以前输入数据的页面,但只要点击两次就可以,这可不是我们希望的
效果,因为很多时候,固执的用户总是能够找到绕过预防措施的办法。
另外一种禁用后退按钮的办法是用客户端javascript打开一个没有工具条的窗口,这使得用户很难返回前一页面,但不是不可能。一种更安全但相当恼人的方法是,当表单提交时打开一个新的窗口,与此同时关闭表单所在的窗口。但我觉得这种方法不值得认真考虑,因为我
们总不能让用户每提交一个表单就打开一个新窗口。
那么,在那个我们不想让用户返回的页面是否也可以加入javascript代码呢?在这个页面中加入的javascript代码可用来产生点击前进按钮的效果,这样也就抵消了用户点击后退按钮所产生的动作。用于实现该功能的javascript代码如下所示:
同样地,这种方法虽然有效,但距离“最好的方法”还差得很远。后来我又看到有人建议用location。
replace从一个页面转到另一个页面。这种方法的原理是,用新页面的url替换当前的历史纪录,这样浏览历史记录中就只有一个页面,后退按钮永远不会变为可用。我想这可能正是许多人所寻求的方法,但这种方法仍旧不是任何情况下的最好方法。使用这种方法的实例如下所示:
1.文章《asp.net 防止用户通过后退按钮重复提交表单》援引自互联网,为网友投稿收集整理,仅供学习和研究使用,内容仅代表作者本人观点,与本网站无关,侵删请点击页脚凯发k8国际手机app下载的联系方式。
2.文章《asp.net 防止用户通过后退按钮重复提交表单》仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证。