浏览器缓存url请求

最近遇到浏览器缓存url的问题,google了一把,学到不少东西,结合网上其他人文章拼凑一篇,供大家交流。

一防止url被浏览器缓存

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

解决办法:

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

例“http://www.example.com/index.php?class=aitcle&page=5&_t=”+newDate().getTime()

2.在ajax发送请求前加上xmlHttpRequest.setRequestHeader(“If-Modified-Since”,”0″)

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

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

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

二.防止jsp页面内容被缓存:

防止JSP页面缓存为了防止浏览器缓存当前访问的JSP动态页面,可以采用如下的方式进行设置:

<%

//将过期日期设置为一个过去时间

response.setHeader("Expires","Sat,6May199512:00:00GMT");

//设置HTTP/1.1no-cache头

response.setHeader("Cache-Control","no-store,no-cache,must-revalidate");

//设置IE扩展HTTP/1.1no-cacheheaders,用户自己添加

response.addHeader("Cache-Control","post-check=0,pre-check=0");

//设置标准HTTP/1.0no-cacheheader.

response.setHeader("Pragma","no-cache");

%>

三.防止html页面被缓存(jsp也适用)

禁止客户端缓存要在<head>中加入类似如下内容:

<METAHTTP-EQUIV="pragma"CONTENT="no-cache">

<METAHTTP-EQUIV="Cache-Control"CONTENT="no-cache,must-revalidate">

<METAHTTP-EQUIV="expires"CONTENT="Wed,26Feb199708:21:57GMT">

<metahttp-equiv="pragma"content="no-cache">

<metahttp-equiv="cache-control"content="no-cache">

<metahttp-equiv="expires"content="0">

相关推荐