html怎样缓存图像,网页如何缓存图片_html/css_WEB-ITnose

网页的图片是 调用服务器action,以数据流的形式写到页面的。

attachFileUploadBySwf!downloadImg.do?id=39780

每次进入页面都会重新下载图片

有没有办法可以缓存图片,在缓存中直接取出

回复讨论(解决方案)

http://www.cnblogs.com/yuyii/archive/2008/10/16/1312238.html

设置Cache-Control

我加上

还是会 去加载图片

图片是个action请求

二进流还能缓存吗?没听说过。页面级缓存都是针对特定资源(xx.扩展名)

这个缓存是在 服务器端实现的 在服务器写出图片留的时候response 增加Last-Modified的参数值,这样浏览器就会将数据缓存起来,当页面再次请求该url的时候请求参数就会带着if-modified-since参数信息,然后判断该参数信息,返回浏览器告知使用缓存数据

下面是部分代码。

//获取缓存文件最后的修改时间(只有缓存过的文件在请求时存在该参数)

String lastUpdateTime = ServletActionContext.getRequest().getHeader("if-modified-since");

//如果存在参数,告知浏览器使用缓存数据

if(lastUpdateTime!=null){

//如果需要判断过期时间,则将文件的最后修改时间与当前时间作比较进行判断

//status:304,使用缓存数据

ServletActionContext.getResponse().setStatus(HttpServletResponse.SC_NOT_MODIFIED);

return null;

}

HttpServletResponse response=ServletActionContext.getResponse();

is = new BufferedInputStream(new FileInputStream(file),1024*1024);

response.setContentType("application/x-download"); // 设置返回的文件类型

response.addHeader("Content-Disposition","attachment;filename="+ URLEncoder.encode(uploadFile.getSaveFileName(), "UTF-8"));

//设计缓存为私有缓存,不在用户之间共享

response.setHeader("Cache-Control", "private");

//重要!,浏览器在response中发现该字段,才会将数据存入缓存中,(标记最后修改时间)

response.setDateHeader("Last-Modified",new Date().getTime());

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值