1、使用session
在提交的页面也就是数据库处理之前:
数据处理完后,修改session("ok")=false。
数据处理成功马上redirect到另外一个页面。
简单地运用response.redirect将不再有效,因为用户从一个页面转到另一个页面,我们都必须用客户端代码清除location.history。注意,这种方法清除的是最后一个访问历史记录,而不是全部的访问记录。
点击后退按钮,再点击后退按钮,你可以看到这时打开的是本页面之前的页面!(当然,这是在你的客户端启用了javascript功能的条件下。)
如果客户按后退,怎么办?
2、防止网页后退--禁止缓存
在进行数据库添加操作时,如果允许后退,而正巧有刷新了页面,就会再次执行添加操作,此时需要在操作的页面加上禁止缓存的功能,在网页的里指定要定向的新页,再点后退,看是不是不会再退到刚才的操作页面了,实际上是删除历史。
代码如下:
通常情况下,无法禁用浏览器的后退按钮。
3、防止网页后退--新开窗口
用window.open弹出表单页面,点提交后关闭该页;处理提交的asp页也是用弹出,设定表单的target,点提交时window.open("xxx.asp","_blank"),然后用js来提交表单,完成后window.close();
提交表单的时候弹出新窗口,关闭本窗口。对于window.open()打开的窗口怎么后退?能后退到哪里去?
这也不失为一种解决方法吧。
以上就今天要介绍的内容,实现网页防刷新、重复提交,防止后退,希望对大家有所帮助。