web 开发之js---页面缓存, jsp 缓存, html 缓存, ajax缓存,解决方法
2014-10-21 13:31
666 查看
有关页面缓存问题.这个问题上网找了好多.但发觉各种解决方法,都彼此分离,没有一篇统一的解决方法,本人近日,也遇到了页面缓存的问题,根据网上各页面缓存的解答,做了一个总结。
1.服务器端缓存的问题, 防止JSP页面缓存:
[java] view plaincopy
<%
// 将过期日期设置为一个过去时间
response.setHeader("Expires", "Sat, 6 May 1995 12:00:00 GMT");
// 设置 HTTP/1.1 no-cache 头
response.setHeader("Cache-Control", "no-store,no-cache,must-revalidate");
// 设置 IE 扩展 HTTP/1.1 no-cache headers, 用户自己添加
response.addHeader("Cache-Control", "post-check=0, pre-check=0");
// 设置标准 HTTP/1.0 no-cache header.
response.setHeader("Pragma", "no-cache");
%>
当然,每一个页面都包含这些代码会很繁琐,可以通过自定义过滤器(Filter)的方法来处理相关的页面
2.防止html页面缓存
[xhtml] view plaincopy
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
3.防止Ajax缓存
如果,你的页面,已经设置了防止JSP,HTML的页面缓存,但发觉页面缓存,始终存在,就要考虑是否Ajax造成的页面缓存了。
1)设置了,如上1,2之后
Ajax缓存,产生的原因是:request, url的地址上:
IE中如果XMLHttpRequest提交的URL与历史一样则使用缓存,根本不向服务器端提交。因此无法取到刚提交的数据。
针对ajax,需要如下设置:
方法一:加时间戳 var url = BaseURL + "&timeStamp=" + new Date().getTime();
方法二:加随机数 var url = BaseURL + "&r=" + Math.random();
总结:原引(http://www.javaeye.com/topic/150162)
在jsp页面中,光是使用html的<meta> tag是无法禁止缓存的。一定要加上
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);
有人肯定会说,这个跟html的tag设置没有不同啊。的确,我也觉得,但实践证明,没有这几句,光靠html tag不行。
所以当action会返回页面时,有以下这两种情况:
a,返回的页面没有写上上面的禁止cache的语句(或者只写了html tag)。IE存储的是URL link + page result(cache eabled)。这也就是导致了之前为什么还会有cache的原因
b,返回的页面写上了禁止cache语句 。IE存储的是URL link + page result(cache disabled)。这样才能够实现到我们想要的目的。每次都会真正的发出request。
总结:页面缓存没有统一的解决方法,要具体问题具体分析.
http://blog.csdn.net/oklzh/article/details/4445722 http://www.blogjava.net/JAVA-HE/archive/2008/11/25/242420.html js write()
1.服务器端缓存的问题, 防止JSP页面缓存:
[java] view plaincopy
<%
// 将过期日期设置为一个过去时间
response.setHeader("Expires", "Sat, 6 May 1995 12:00:00 GMT");
// 设置 HTTP/1.1 no-cache 头
response.setHeader("Cache-Control", "no-store,no-cache,must-revalidate");
// 设置 IE 扩展 HTTP/1.1 no-cache headers, 用户自己添加
response.addHeader("Cache-Control", "post-check=0, pre-check=0");
// 设置标准 HTTP/1.0 no-cache header.
response.setHeader("Pragma", "no-cache");
%>
当然,每一个页面都包含这些代码会很繁琐,可以通过自定义过滤器(Filter)的方法来处理相关的页面
2.防止html页面缓存
[xhtml] view plaincopy
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
3.防止Ajax缓存
如果,你的页面,已经设置了防止JSP,HTML的页面缓存,但发觉页面缓存,始终存在,就要考虑是否Ajax造成的页面缓存了。
1)设置了,如上1,2之后
Ajax缓存,产生的原因是:request, url的地址上:
IE中如果XMLHttpRequest提交的URL与历史一样则使用缓存,根本不向服务器端提交。因此无法取到刚提交的数据。
针对ajax,需要如下设置:
方法一:加时间戳 var url = BaseURL + "&timeStamp=" + new Date().getTime();
方法二:加随机数 var url = BaseURL + "&r=" + Math.random();
总结:原引(http://www.javaeye.com/topic/150162)
在jsp页面中,光是使用html的<meta> tag是无法禁止缓存的。一定要加上
response.setHeader("Pragma","No-cache");
response.setHeader("Cache-Control","no-cache");
response.setDateHeader("Expires", 0);
有人肯定会说,这个跟html的tag设置没有不同啊。的确,我也觉得,但实践证明,没有这几句,光靠html tag不行。
所以当action会返回页面时,有以下这两种情况:
a,返回的页面没有写上上面的禁止cache的语句(或者只写了html tag)。IE存储的是URL link + page result(cache eabled)。这也就是导致了之前为什么还会有cache的原因
b,返回的页面写上了禁止cache语句 。IE存储的是URL link + page result(cache disabled)。这样才能够实现到我们想要的目的。每次都会真正的发出request。
总结:页面缓存没有统一的解决方法,要具体问题具体分析.
http://blog.csdn.net/oklzh/article/details/4445722 http://www.blogjava.net/JAVA-HE/archive/2008/11/25/242420.html js write()
相关文章推荐
- 页面缓存, jsp 缓存, html 缓存, ajax缓存,解决方法
- 页面缓存, jsp 缓存, html 缓存, ajax缓存,解决方法
- 页面缓存, jsp 缓存, html 缓存, ajax缓存,解决方法
- 页面缓存, jsp 缓存, html 缓存, ajax缓存,解决方法
- Ajax 动态载入html页面后不能执行其中的js快速解决方法
- 在(ASP/PHP/JSP/html/js)中禁止ajax缓存的方法集锦
- JSP缓存、HTML 缓存、AJAX缓存的解决方法
- jsp 缓存, html 缓存, ajax缓存,解决方法
- 在(ASP/PHP/JSP/html/js)中禁止ajax缓存的方法集锦
- js中对arry数组的各种操作小结 瀑布流AJAX无刷新加载数据列表--当页面滚动到Id时再继续加载数据 web前端url传递值 js加密解密 HTML中让表单input等文本框为只读不可编辑的方法 js监听用户的键盘敲击事件,兼容各大主流浏览器 HTML特殊字符
- tomcat发布web项目JSP页面打开报空指针异常解决方法。
- C#后台程序与HTML页面中JS方法互调(功能类似于Ajax中的DWR)
- 【JSP】让HTML和JSP页面不缓存的方法
- Eclipse/MyEclipse 开发JSP页面卡死的解决方法
- document.oncontextmenu页面右键菜单功能(2008-09-04 17:49:31| 分类: jsp+html+js+Ajax)
- 关于ajax页面里的js方法无法使用的解决办法
- js传汉字在UTF-8标准的JSP页面中乱码的解决方法
- JSP、AJax中文乱码问题解决,escape(), encodeURI(), encodeURIComponent(),js对参数连续两次调用 encodeURI(String) 方法
- 解决JSP开发Web程序中文显示三种方法
- 老手讲解在JSP开发中与Web的中文问题解决方法