js清除缓存以及jsp缓存[部分常用]

参考:

http://bbs.csdn.net/topics/330028896  浏览器缓存机制

http://www.docin.com/p-591569918.html  浏览器缓存的一些问题的处理方法

 

部分浏览器缓存问题的解决方案

1.GET请求缓存处理,不想要缓存GET请求?

浏览器会缓存GET请求,不会缓存POST请求,因此解决为:

方法1:GET请求URL后加随机数,让服务器认为是不同的请求,如:"http://www.example.com/index.jsp?class=articele&page=5&t" new Date().getTime();

方法2:在ajax发送请求前加上xmlHttpRequest.setRequestHeader("If-modified-since","0");

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

方法4:若为jquery ajax, 设置ajax属性cache:false;(注意:cache属性对post没有用,对get才有用)

方法5:在服务器端响应请求时加上response.setHeader("Cache-Control","no-cache,must-revalidate");

方法6:使用POST代替GET,浏览器不会对POST做缓存

注意:为什么cache属性对post没有用,对get才有用?

因为1.浏览器缓存url请求原理就是判断url是否相同,url相同则读取缓存,url不相同则读取服务器

2.使用GET方式提交url类似"http://www.example.com/index.jsp?class=articele&page=5“,而POST方式提交url类似http://www.example.com/index.jsp,参数是在请求  head里的,不在url上,请求参数url始终相同

3.jquery ajax GET方式提交: data: "t=" new Date().getTime(),  或者 data:{"t": new Date().getTime()}或者cash:false都是在请求后面加上不同的参数,cach:false会启动 生成参数附加在url请求里,因此浏览器认为是不同的请求,就重新请求服务器。

 

2.防止JSP动态页面内容被缓存?

方法:在JSP页面里 头部

<%
response.setHeader("expires","sat,6 May 1995 12:00:00 GMT");//将expire时间设置为一个过去时间或0,-1等
response.setHeader("cache-control","no-store,no-cache,must-revalidadate");//设置HTTP/1.1 cache-control头
response.addHeader("cache-control", "post-check=0,pre-check=0");//设置IE 扩展HTTP/1.1 no-cache header
response.setHeader("Pragma", "no-cache");//设置标准HTTP/1.0 no-cache header
%>

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

方法:html页面里

注意:

1.若在jsp页面里"<%response%>"添加页面过期 "<meta http-equiv>"添加不过期,则页面过期.

2.若在jsp页面里"<%response%>"添加页面不过期 "<meta http-equiv>"添加过期,则页面不过期.

<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">

 

3.cache-control参数说明:

a.max-age=""指示客户机可以接受生存期小于指定时间的响应,以s为单位,在max-age规定的秒数内,浏览器将不会发送对应的请求到服务器,数据由缓存直接返回,超过这一时间段才进一步由服务器决定是返回新数据还是仍由缓存提供。

b.public 指示响应可被任何缓存区缓存;

c.private 指示对于单个用户的整个或部分响应消息,不能被共享缓存处理,这允许服务器描述当用户的部分响应效益,此响应消息对于其他用户的请求无效;

d.no-cache 指示请求或响应消息不能缓存;

e.no-store用于防止重要的信息被无意发布,在请求消息中发送将使得请求和响应消息都不缓存;

f.min-fresh指示客户机可以接收响应时间小于当前时间加上指定时间的响应;当前时间加上指定时间内,浏览器不会发送消息到服务器

g.max-stale:指示客户机可以接收超出超时期间的响应消息,如果指定max-stale消息的值,那么客户机可以接收超出超时期指定值之内的响应消息。

 PS:仅作记录-笔记

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
清除input输入框的缓存,有两种方法可以选择。首先,你可以在不想使用缓存的input输入框中添加`autocomplete="off"`属性。例如:`<input type="text" name="name" autocomplete="off"/>`。这样做可以告诉浏览器不要缓存该输入框的值。 另外一种方法是使用`onfocus`事件来清除缓存。你可以在input输入框的标签中添加`onfocus="this.value=''"`属性。这样当用户点击输入框时,输入框中之前的缓存值会被清除掉。 这种方法可以更灵活地控制清除缓存的时机。 综上所述,你可以选择添加`autocomplete="off"`属性或使用`onfocus`事件来清除input输入框的缓存。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [清除JSP中input输入框的缓存](https://blog.csdn.net/qq_36816062/article/details/112709644)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [清除input输入框的缓存](https://blog.csdn.net/a631464421/article/details/107856263)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值