专栏首页偏前端工程师的驿站网页优化系列二:使用Cache缓存静态文件、图片(asp.net版)

网页优化系列二:使用Cache缓存静态文件、图片(asp.net版)

  网站中存在一些不会经常变更的内容如静态文件、图片等,我们称之为静态资源。针对这些静态资源使用cache缓存到客户端中,以减少用户再次浏览该网页时的请求量,从而加速了网页的加载、呈现速度。同样,要设置静态资源缓存到客户端,我们需要加一个中间层来处理静态资源的请求。下面以图片为例进行说明。(若图片十分巨大情况下才使用该方法,若图片k级数的话,初次加载速度会更慢,因为IIS对于静态文件和动态文件的处理是不同的,如果图片容量小,动态文件处理的时间占大部分总体加载时间)

未优化:

  Default.aspx

1 <html>
2   <head>
3   <head>
4   <body>
5      <img src="images/back.gif"/>
6   <body>
7 </html>

首次访问和再次访问页面都要向服务器请求图片。

优化后:

 Default.aspx:

1 <html>
2  <head>
3  <head>
4  <body>
5    <img src="ImageRequestHandler.ashx?p=images/back.gif"/>
6  <body>
7 </html>

ImageRequestHandler.ashx

 1 public void ProcessRequest (HttpContext context) {
 2         string path = context.Server.MapPath(context.Request.QueryString[0]);
 3         string suffix = path.Split('.')[path.Split('.').Length-1];
 4         context.Response.ContentType = string.Format("image/{0}",suffix.ToLower().Equals("png")?"x-png":suffix);//设置MIME,如果是png文件,MIME信息为text/x-png
 5         context.Response.Expires = 60*24*30;//设置图片30天过期
 6         ImageFormat ift = ImageFormat.Jpeg;//设置默认文件格式
 7         Image img = Image.FromFile(path);
 8         if(suffix.ToLower().Equals("gif"))
 9         {
10             ift = ImageFormat.Gif;
11         }else if(suffix.ToLower().Equals("png"))
12         {
13             ift = ImageFormat.Png;
14         }
15         MemoryStream ms = new MemoryStream();
16         img.Save(ms,ift);
17         context.Response.OutputStream.Write(ms.GetBuffer(),0,ms.Length);

  这里只处理了gif、Jpeg和png格式的图片文件,其他格式的图片文件大家按实际添加修改。假如处理中没有png格式的文件,那么15行至17行的代码可以改写成

img.Save(context.Response.OutputStream,ift);

那是为什么呢?那是因为Response.OutputStream这个流的无法往回读取造成的,也就是它的CanSeek属性是false。png图像生成的时候不像jpeg,不是流式的,已经写入的就不再管了,而是需要往回不断地写入结构数据。但是response流无法往回seek,所以直接用就不行了。改成一个可以seek的MemoryStream,先生成好png图片,然后再输出到response流。否则会出现GDI+一般性错误。

请求数一样但图片是从cache中获取的,也没有出现请求服务器后,服务器返回304的情况。

下面总结一下设置文件缓存到cache后,触发读取cache已有文件的操作。前提:文件还没过期

1.在浏览器地址栏输入地址,按跳转;

2.点击页面上的超链接;

3.触发服务器控件的事件;

4.脚本代码使用window.open(),location.href='',location.assign(),location.replace()。

下面是即使文件还没过期也不会读取cache中已有文件的操作。

1.按浏览器的刷新按钮;

2.脚本代码使用location.reload()。

关于浏览器的后退和前进按钮,它们与文件是否启用了缓存无关。它们是调用的是history cache中的文件。

更多:网页优化系列三:使用压缩后置viewstate

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • JS魔法堂:再识Number type

    Brief                                   本来只打算理解JS中0.1 + 0.2 == 0.300000000000000...

    ^_^肥仔John
  • CMD魔法堂:支持显示UTF8编码的中文

    一、前言                                     在Unbuntu中用sqlite3-command-line操作sqlite3...

    ^_^肥仔John
  • 静态页面设置缓存、动态页面设缓存(不断更新中。。。。)

      1.静态的html页面想要设置使用缓存:<meta http-equiv="expires" content="utc时刻"/>,目前我只明确该方法可行。如...

    ^_^肥仔John
  • Machine Learning笔记——多变量线性回归

    在之前的单变量线性回归问题中,我们是通过房屋的大小来作为预测房屋价格。但是我们知道了很多其他的变量,例如卧室的数量,楼层的数量,房子的年龄等。

    阳光罗诺
  • 常见编码问题UnicodeEncodeError

    python 里面的编码和解码也就是 unicode 和 str 这两种形式的相互转化。编码是 unicode -> str,相反的,解码就是 str -> u...

    意气相许的许
  • Mac:github 下载慢的问题

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

    菜菜不吃蔡
  • Snova运维篇(六): snova平台子用户及协作者管理

    snova-最佳实践
  • Windows Server 2008 R2系统无法远程连接登陆初步排查

    点左上角“发送远程命令”,选择“Ctrl-Alt-Delete”,使服务器当前界面进入到输密码的界面;

    夏日萤火
  • 扒虫篇-Bug日志 Ⅱ

    事情是这样的:一个风和日丽的下午,我正在 itunesConnect 中注册一个APP,基本信息都保存了,在编辑版本信息时,都弄的差不多了,可是没有保存,结果不...

    進无尽
  • RaspberryPi接入HomeKit

    是一个轻量的NodeJS服务,你可以在你家的局域网中运行这个来模拟IOS HomeKit API。它支持很多插件,提供基本的桥来将一些智能家居厂商提供的第三方A...

    治电小白菜

扫码关注云+社区

领取腾讯云代金券