彻底终结浏览器Cache页面的解决方案
时间:2008-04-21 15:10:00
浏览器经常Cache你的页面,这是一个很麻烦的问题,下面先提出几种方案来解决一般的问题:(把下面的代码加入到asp程序的最开始位置)
<%
response.expires = 0
response.expiresabsolute = Now() - 1
response.addHeader "pragma","no-cache"
response.addHeader "cache-control","private"
Response.CacheControl = "no-cache"(或则设置为Private)
%>
请注意分析上面的方法:
这方法可以一般的终结浏览器缓存页面。但是它们对IE5是无能为力的,对于IE5只能够使用第5种方法。上面的方法都是针对IE浏览器的,它们告诉IE浏览器关闭缓存页面功能。
但是十分不幸的是,即使如此,NetScape浏览器还是将缓存页面。
要最终不让浏览器缓存页面,在编程的时候就会付出很多。其实缓存页面对于纯粹的HTML页面来说是很有用的,它可以减轻服务器的压力。但是它对于动态的asp来说简直就是灾难,特别是如果你是开发一个电子商务程序时,例如一个购物车程序,你会发现你订购的东西突然会莫名其妙的消失了,或者本来已经被删除掉的货物怎么会突然出现在购物车内呀,所以,往往你会付出很大的代价来解决缓存页面这个 * 烦:
1。尽量小心使用Response.redirect,不要到处乱用。
2。可以使用下面的两个函数替代redirect.用一个带?号的url传递给函数Redirect,这样每次生成的连接到下一页的url将不同,不同的url将会让所有的浏览器终止缓存同一个页面的,呵呵,是个比较有意思的方法。这也是我推荐的第下面方法。
Function Redirect( NewURL )
If Not IsEmpty( NewURL & "" ) Then
Dim QuestionMark
QuestionMark = Instr( NewURL, "?" )
If QuestionMark = 0 Then
Response.Redirect NewURL & "?" & NoCacheURL()
Response.End
Else
Response.Redirect NEWURL & "&" & NoCacheURL()
Response.End
End If
End If
Function NoCacheURL()
On Error Resume Next
Randomize
' 一般是两种生成随机连接的方法,如果你使用Now()的话,就不用使用Randomize了
NoCacheURL = "NoCache=" & Server.URLEncode(rnd)
' 或则NoCacheURL = "NoCache=" & Server.URLEncode(Now())
End Function
标签:Cache,浏览器,缓存,asp
0
投稿
猜你喜欢
解决vscode中golang插件依赖安装失败问题
2024-04-26 17:23:15
pyqt5实现绘制ui,列表窗口,滚动窗口显示图片的方法
2023-03-22 16:52:56
Vue 列表渲染 key的原理和作用详解
2024-05-03 15:11:21
用Dreamweaver设计Wordpress留言板教程(一)
2010-03-17 15:44:00
Python基于tkinter模块实现的改名小工具示例
2023-08-31 10:40:01
IE 浏览器安全级别详情及区别小结
2022-05-28 20:24:16
vscode调试django项目的方法
2022-03-07 01:02:51
Python装饰器的函数式编程详解
2023-12-27 16:35:31
python实现xml转json文件的示例代码
2023-09-29 23:52:50
如何查看MySQL连接的root密码
2024-01-25 08:47:43
三种Python比较两个时间序列在图形上是否相似的方法分享
2023-04-26 20:57:12
python数据结构之二叉树的统计与转换实例
2023-08-11 07:35:48
Python保姆式手把手带你掌握异常的捕获和处理
2022-04-30 14:10:18
Oracle的out参数实例详解
2024-01-17 00:34:23
SQL语句中JOIN的用法场景分析
2024-01-15 05:05:49
详解TreeView绑定数据库
2024-01-17 17:09:13
浅谈Python中的数据类型
2022-11-29 06:19:22
关于select元素的两个小问题
2008-12-25 13:41:00
sql 修改表的所有者
2024-01-14 15:05:19
Python实现构建一个仪表板的示例代码
2023-10-03 11:53:27