解决方法如下:
第一种是ASP.NET清除页面缓存
Response.Buffer
=
true
Response.ExpiresAbsolute
=
System.DateTime.Now.AddSeconds(-1)
Response.Expires
=
0
Response.CacheControl
=
"no-cache"
Response.AddHeader("Pragma",
"No-Cache")
第二种是HTML方法<HEAD<META
HTTP-EQUIV="Pragma"
CONTENT="no-cache"
<META
HTTP-EQUIV="Cache-Control"
CONTENT="no-cache"
<META
HTTP-EQUIV="Expires"
CONTENT="0"</HEAD第三种是重新调用原页面的时候在给页面传一个参数:
href="****.ASPX?random()"
最后一种是在在页面中禁用缓存
在web开发中合理使用缓存可以有效的提高网站的性能,但是在某些场合下因为缓存的存在会带来很多的问题。
例如:因为缓存的存在会造成重复提交数据的问题,验证码图片不能正确显示的问题
,等等。这个时候我们就要禁用页面缓存的功能。
我们常用的做法是发送一个no-cache的指令,但是实际使用过程中我们发现,这个指令对IE是有效的,但是对Firefox却没有效,这是因为,使用该指令Firefox不缓存HTTPS
pages
但是还是会缓存HTTP
pages
,这是Firefox的一个BUG,解决的办法很简单,就是使用no-store代替no-cache,同时发送no-store和no-cache指令
ASP.net中的处理方法,在不需要缓存的页面中添加如下代码
方法一:在开发中有时并不希望页面被缓存,特别是弹出式窗体,可以使用一下方法处理,将页面设置为不缓存。
方法一:在页面文件的HEAD中添加
<HEAD>
<META
HTTP-EQUIV="Pragma"
CONTENT="no-cache">
<META
HTTP-EQUIV="Cache-Control"
CONTENT="no-cache">
<META
HTTP-EQUIV="Expires"
CONTENT="0">
</HEAD>
方法二
:在后端代码中添加,建议放在
Page_Load
事件中
Page.Response.Buffer
=
false
Page.Response.Cache.SetNoStore()