最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
Ajax禁止缓存的几个解决方案
时间:2022-11-14 22:02:49 编辑:袖梨 来源:一聚教程网
最常用的方法是
方法1:服务器端代码加入
代码如下 | 复制代码 |
response.setHeader("Cache-Control", "no-cache, must-revalidate"); |
方法2:用JavaScript在Ajax提交的时候加入一个随机数作为URL中的一个参数。
代码如下 | 复制代码 |
req.open(url + "&" + Math.random). |
原因:IE中如果XMLHttpRequest提交的URL与历史一样则使用缓存,根本不向服务器端提交。因此无法取到刚提交的数据。
1.在服务端加 header("Cache-Control: no-cache, must-revalidate");(如php中)
2.在ajax发送请求前加上 anyAjaxObj.setRequestHeader("If-Modified-Since","0");
3.在ajax发送请求前加上 anyAjaxObj.setRequestHeader("Cache-Control","no-cache");
4.在 Ajax 的 URL 参数后加上 "?fresh=" + Math.random(); //当然这里参数 fresh 可以任意取了
5.第五种方法和第四种类似,在 URL 参数后加上 "?timestamp=" + new Date().getTime();
6.用POST替代GET:不推荐
加个随机数:
代码如下 | 复制代码 |
xmlHttp.open("GET", "ajax.asp?now=" + new Date().getTime(), true); |
实例
代码如下 | 复制代码 |
function saveUserInfo() |
在要异步获取的asp页面中写一段禁止缓存的代码:
代码如下 | 复制代码 |
Response.Buffer =True Response.ExpiresAbsolute =Now() - 1 Response.Expires=0 Response.CacheControl="no-cache" |
在ajax发送请求前加上xmlHTTP.setRequestHeader("If-Modified-Since","0");可以禁止缓存
代码如下 | 复制代码 |
xmlHTTP.open("get", URL, true); xmlHTTP.onreadystatechange = callHTML; xmlHTTP.setRequestHeader("If-Modified-Since","0"); xmlHTTP.send(); |
AJAX的缓存是由浏览器维持的,对于发向服务器的某个url,ajax仅在第一次请求时与服务器交互信息,之后的请求中,ajax不再向服务器提交请求,而是直接从缓存中提取数据。
有些情况下,我们需要每一次都从服务器得到更新后数据。思路是让每次请求的url都不同,而又不影响正常应用:在url之后加入随机内容。
url=url+"&"+Math.random();
1.每次请求的url都不一样(ajax的缓存便不起作用)
2.不影响正常应用(最基本的)
在JSP中禁止缓存:
代码如下 | 复制代码 |
response.addHeader("Cache-Control", "no-cache"); |
html实现方法
代码如下 | 复制代码 |
|
相关文章
- 云星穹铁道权益升级怎么玩 云崩铁权益升级活动介绍 12-03
- 以闪亮之名山中绘梦怎么玩 以闪亮之名滢然花梦套装活动介绍 12-03
- 以闪亮之名绿野梦歌礼包怎么样 以闪亮之名绿野梦歌拍照礼包介绍 12-03
- 光遇12.6有什么更新 光遇12月6日更新内容介绍 12-03
- 伍六七暗影交锋测试资格怎么获得 伍六七暗影交锋内测资格获取方法 12-03
- 无限暖暖晶莹诗集怎么样 12-03