浏览器java过期怎么回事_谈谈浏览器的缓存过期时间

今天和同事在讨论浏览器的缓存问题。正好之前有遇到过,当时一时没有想清楚它的缓存机制,所以晚上正好有时间仔细研究了一下。

浏览器为什么要缓存?什么会缓存下来?

首先当我们访问网页的时候,很多大的图片从服务器上传输过来的时候,试想一下,如果浏览器不把图片缓存下来而是每次都要到服务器去取,那么每次都给服务器和网络造成了巨大的负担。

对于静态资源来说,浏览器不会缓存html页面的,所以你每次改完html的页面的时候,html都是改完立即生效的,不存在什么有缓存导致页面不对的问题。浏览器缓存的东西有图片,css和js。这些资源将在缓存失效前调用的时候调用浏览器的缓存内容。

怎么让浏览器的缓存的东西不失效?

文档里有种说法是吧header中的Expires:设置为Sun, 17-Jan-2038 19:14:07 GMT,因为这个时间是32位unix支持的最大的时间值

但是网上有种说法就是IIS6 最大的时间只能到31-Dec-2035

If you’re using IIS6 you’ll find that the UI won’t allow anything beyond 31-Dec-2035.

总之我们把这个时间设置到很大就可以了。下面是访问google时一个response返回的值。

补充一下,如果expires的时间为-1,那么缓存会立即失效。如果是一个将来时间,那么它将在将来时间失效

bd18cc406a6dc805230f2a691fb2b82e.png

怎么让浏览器不缓存静态资源?

一种方式就是让你的页面有这样的header,Cache-Control: no-cacheheader,这样浏览器就不会缓存静态资源了,每次取数据的时候都去服务器上重新获取。

补充一下,如果设置no-cache的时候对IE是有效的,但是对于firefox是不行的,如果让firefox也不缓存要在header中加一个Cache-Control: no-cache, no-store

另外一种方式就是让你的静态资后缀加上一个版本号,比如

    如果这个version有改变的话,下次就会重新获取这个静态资源。这样做的好处就是由你来控制什么时候来获取新的版本的静态资源。

如果不设置这些浏览器用什么来控制缓存失效?

header中有一个参数叫Last-Modified,这个是由服务器自动加上的,如果有这个参数,那么浏览器每次都会重新计算本地的cache。如果浏览器返回一个304的编码就表示资源没有改变,那么浏览器就可以使用本地的cache。

就如参考文档中说的,对于IE来说,如果没有设置expirse header的时候,IE的缓存时间就是一个session的时间,如果用户打开一个新的IE窗口的时候,他们就会获取最新的静态资源。但是对于firefox来说它就不是这样了,它是依赖last—modified的时间的(HTTP 1.1 spec RFC2616)。

Also, if the response does have a Last-Modified time, the heuristic expiration value SHOULD be no more than some fraction of the interval since that time. A typical setting of this fraction might be 10%.

也就是说firefox的失效时间=现在时间+0.1*(time-last-modified ),就是他将在它上一次修改时间的十分之一的时间差的时候失效。

为什么这么做呢?我们可以想象一个文件越久没有修改,那么它就越稳定,所以缓存的时间也就越长。只是这个时间差要除以下10。

比如一个文件上次修改时间为100天之前,那么那10天后才会失效。

总结一下,以前对浏览器的缓存及失效了解的不是很透彻,具体是如何失效的也不太清楚,那么现在对于如何能改变缓存,永久缓存及合适能失效都有了比较详细的了解。另外要注意的就是IE和firefox的机制还是有很大区别的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用 Java 中的 ConcurrentHashMap 数据结构和 ScheduledExecutorService 实现带过期时间缓存。具体实现步骤如下: 1. 创建一个 ConcurrentHashMap 对象来存储缓存数据,key 为缓存的键,value 为缓存的值和过期时间。 2. 创建一个 ScheduledExecutorService 组件,用来定期清理过期缓存。 3. 实现一个 put 方法来向缓存中添加数据,该方法会将数据存入 ConcurrentHashMap 中,并且将过期时间也存入 value 中。 4. 实现一个 get 方法来从缓存中获取数据,该方法会先检查数据是否过期,如果过期则删除该数据并返回 null,否则返回缓存数据的值。 5. 实现一个定时任务,定期遍历 ConcurrentHashMap,删除过期缓存数据。 实现代码示例: ```java import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.Executors; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.TimeUnit; public class ExpireCache<K, V> { private final ConcurrentHashMap<K, V> cache = new ConcurrentHashMap<>(); private final ConcurrentHashMap<K, Long> expireTime = new ConcurrentHashMap<>(); private final ScheduledExecutorService executorService = Executors.newSingleThreadScheduledExecutor(); public ExpireCache() { // 定时任务,每隔 1 秒遍历缓存并删除过期数据 executorService.scheduleWithFixedDelay(() -> { long now = System.currentTimeMillis(); cache.forEach((k, v) -> { Long expire = expireTime.get(k); if (expire != null && now > expire) { cache.remove(k); expireTime.remove(k); } }); }, 1, 1, TimeUnit.SECONDS); } public void put(K key, V value, long expireAfter) { cache.put(key, value); expireTime.put(key, System.currentTimeMillis() + expireAfter); } public V get(K key) { V value = cache.get(key); if (value != null) { Long expire = expireTime.get(key); if (expire == null || System.currentTimeMillis() <= expire) { return value; } else { cache.remove(key); expireTime.remove(key); } } return null; } } ``` 使用示例: ```java ExpireCache<String, String> cache = new ExpireCache<>(); cache.put("key1", "value1", 5000); // 缓存 5 秒 cache.put("key2", "value2", 10000); // 缓存 10 秒 // 获取缓存数据 System.out.println(cache.get("key1")); // 输出 value1 System.out.println(cache.get("key2")); // 输出 value2 Thread.sleep(6000); // 等待 6 秒 // 获取缓存数据 System.out.println(cache.get("key1")); // 输出 null System.out.println(cache.get("key2")); // 输出 value2 Thread.sleep(5000); // 等待 5 秒 // 获取缓存数据 System.out.println(cache.get("key2")); // 输出 null ``` 在上述示例中,使用 ExpireCache 类来实现带过期时间缓存缓存数据的过期时间分别为 5 秒和 10 秒。在获取缓存数据时,如果数据已经过期,则返回 null,否则返回缓存数据的值。缓存数据的清理是通过定时任务来实现的,每隔 1 秒遍历缓存并删除过期数据。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值