IE下Ajax缓存问题的解决办法(get方式)

折腾了半天,程序中使用jquery的load方法进行请求,很奇怪为啥第二次无法发送请求。百度了一把,谁知load是用get方式进行请求的,因此IE浏览器对

其进行缓存了。网上搜了很多解决方案,一大把,下面是我认为比较全面的解决方案。主要分为客户端解决和服务端解决。

1.客户端解决方案

IE访问策略:Internet选项--浏览历史记录--设置-- Internet 临时文件的选项改为每次访问网页时也可以

1: 在AJAX请求的页面后加个随机函数,我们可以使用随机时间函数

在javascript发送的URL后加上t=Math.random()
例如这样:URL+"&"+"t="+Math.random();或者new Date();

2: 在XMLHttpRequest发送请求之前加上XMLHttpRequest.setRequestHeader("If-Modified-Since","0")

一般情况下,这里的XMLHttpRequest不会直接使用
你应该可以找到这样的代码
XXXXX.send(YYYYYY);
那么,就把它变成
XXXXX.setRequestHeader("If-Modified-Since","0");
XXXXX.send(YYYYYY);
实践证明,两种方法都非常有效。
1、在服务端加 header("Cache-Control: no-cache, must-revalidate");
2、在ajax发送请求前加上 xmlHttpRequest.setRequestHeader("If-Modified-Since","0");
3、在ajax发送请求前加上 xmlHttpRequest.setRequestHeader("Cache-Control","no-cache");
4、在 Ajax 的 URL 参数后加上 "?fresh=" + Math.random(); //当然这里参数 fresh 可以任意取了
5、第四种方法和第三种类似,在 URL 参数后加上 "?timestamp=" + new Date().getTime(); //推荐使用这种方式
6、用POST替代GET:不推荐

2.服务器端解决方案:

以Struts2为例:
Struts2 Server端用法
Xml代码 收藏代码
  1. <packagename="json-nocache"extends="json-default">
  2. <interceptors>
  3. <interceptorname="cachingHeadersInterceptor"class="com.ssa.pct.web.interceptor.CachingHeaderInterceptor"/>
  4. <interceptor-stackname="defaultSecurityStack">
  5. <interceptor-refname="defaultStack"/>
  6. <interceptor-refname="cachingHeadersInterceptor"/>
  7. </interceptor-stack>
  8. </interceptors>
  9. <default-interceptor-refname="defaultSecurityStack"/>
  10. </package>
Java代码 收藏代码
  1. publicclassCachingHeaderInterceptorextendsAbstractInterceptor{
  2. privatestaticfinallongserialVersionUID=1L;
  3. publicStringintercept(ActionInvocationinvocation)throwsException{
  4. ActionContextcontext=invocation.getInvocationContext();
  5. HttpServletResponseresponse=(HttpServletResponse)context.get(StrutsStatics.HTTP_RESPONSE);
  6. if(response!=null){
  7. response.setHeader("Cache-Control","no-cache");
  8. response.setHeader("Pragma","no-cache");
  9. response.setHeader("Expires","-1");
  10. }
  11. returninvocation.invoke();
  12. }
  13. }


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值