浏览器缓存问题

在做新闻系统时利用ajax删除内容,然后刷新浏览器数据依然是回复到原状态,而且在删除已经删除的记录时依然好似 提示成功,这原先以为是服务端的问题,便把response 设置了一下,可还是不行,这样的就只能是从ajax下手了,从url+=“&fresh=”+Math.random(); 或者是设置timestamp=new Date().getTime();也设置了header依然是没用用处,最后看到了一个小小的问题,在做页面的时候是把所有的内容通过加载JavaScript利用ajax进行动态加载,这样的话虽然是利用ajax从数据库中删除了数据,但是每次页面在刷新的时候,原来的javascript是通过传参的形式url,来的,url没变,ie浏览器也就没有从服务端从新加载了,这样的话便产生了缓存,利用fresh这样的方法便可以有用了

所得结果是:以后要是做到ajax加载内容时,url一定要加上fresh或者是timestamp或者随机数random  Math.random new Date

转载如下http://blog.sina.com.cn/s/blog_530fe9870100kcl4.html

项目中要实现一个邮件发送的功能,当填入邮箱后点击发送,页面不刷新,只给出一个“邮件正在发送中”的提示信息,使用ajax发送请求,并根据 ajax请求的返回值来刷新提示信息(如果返回true,提示信息刷新为“邮件已经成功发送,请注意查收”)。当再次点击发送时(邮件地址不变),提示信息又变为“邮件正在发送中”,将邮件在发送一次。在firefox下面运行一起正常,但是在ie下面就出问题了,当邮件地址不变时,第二次点击发送,邮件提示信息仍为“邮件发送成功,请注意查收”(其实是先刷新为“邮件正在发送中”,再被刷新为“邮件发送成功......”的,只不过中间的时间差太小,看不到这个过程),邮件也没有被再次发送。

    感觉是缓存的问题,g了下,找到篇不错的文章,转载如下:

    (原文:http://hi.baidu.com/bit_kevin/blog/item/70648cdd21e357315982dd91.html )

在Ajax开发中,会遇到浏览器缓存内容的问题,比如,某个元素注册了鼠标事件(onmouseover),事件触发后会通过xmlhttprequest到服务器获取内容,在不刷新页面的情况下,浏览器会缓存第一次请求的内容,服务端更新后浏览器仍然显示第一次的内容。

通常,这种请求都是xmlhttprequest发起的GET请求。根据 HTTP 规范,GET 用于信息获取,而且应该是幂等的。也就是说,当使用相同的URL重复GET请求会返回预期的相同结果时,GET方法才是适用的。当对一个请求有副作用的时候(例如,提交数据注册新用户时),应该使用POST请求而不是GET。 所以浏览器会对GET请求做缓存处理。

解决办法:

一. GET请求URL后加随机数,让服务器认为不是相同的请求。

例 "http://www.example.com/index.php?class=aitcle&page=5&_t=" + new Date().getTime()

二. 在ajax发送请求前加上 xmlHttpRequest.setRequestHeader("If-Modified-Since","0")

三. 在ajax发送请求前加上 xmlHttpRequest.setRequestHeader("Cache-Control","no-cache");

四. 服务端响应请求时加 header("Cache-Control: no-cache, must-revalidate"); (PHP)

五. 使用POST代替GET,浏览器不会对POST做缓存

                                  

附录:

RFC1945中的英文原文如下:

8.1 GET

The GET method means retrieve whatever information (in the form of an
entity) is identified by the Request-URI. If the Request-URI refers
to a data-producing process, it is the produced data which shall be
returned as the entity in the response and not the source text of the
process, unless that text happens to be the output of the process.

The semantics of the GET method changes to a "conditional GET" if the
request message includes an If-Modified-Since header field. A
conditional GET method requests that the identified resource be
transferred only if it has been modified since the date given by the
If-Modified-Since header, as described in Section 10.9. The
conditional GET method is intended to reduce network usage by
allowing cached entities to be refreshed without requiring multiple
requests or transferring unnecessary data.

                    

参考文献:

[1] 浏览器缓存 ajax cache 问题[N] http://batmanwl.blog.sohu.com/71841783.html

浏览器缓存相关:

http://zhidao.baidu.com/question/28162620.html?si=3

http://hi.baidu.com/byromivy/blog/item/09768d2b35577bfee6cd40a7.html

http://hi.baidu.com/2hill/blog/item/445f8db42412cc778ad4b24e.html  (讲的很清楚了 )

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值