网页优化系列二:使用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
- Android中的FragmentManager的问题
- Premiere Pro & After Effects插件开发调试方法
- RegQueryValueEx正确使用方法
- 区块链+医疗五类应用前景广阔,英美已有企业试水
- Linux进程关系
- 基于OBS的插件开发总结
- Linux从程序到进程
- asp.net 解码gb2312下urlencode后的字符串
- XCode日常使用备忘录
- .net中close和dispose及关闭流操作
- Linux文件管理相关命令
- 实现滑动分页(微博分页方式)
- 腾讯汇赢正式上线,变革2018大连房地产市场营销
- Windows下程序启动时出现0xc000007b错误的解决方案
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Android开发简易音乐播放器
- Android 自定义ListView实现QQ空间界面(说说内包含图片、视频、点赞、评论、转发功能)
- Android自定义View实现自动吸附功能
- Qt音视频开发35-Onvif图片参数
- alpine安装openssl
- iOS14中的PHPicker
- Android 如何实现动态申请权限
- Android录屏的三种解决方案
- Android 实现将Bitmap 保存到本地
- Android Gradle依赖管理、去除重复依赖、忽略的方式
- Andriod Studio实现保存QQ密码功能(案例代码详解)
- Android Studio编写微信页面提交功能
- android 实现按钮浮动在键盘上方的实例代码
- 创建Android守护进程实例(底层服务)
- android studio xml文件实现添加注释