Asp.net 程序优化js,css合并与压缩
访问时将js和css压缩并且缓存在客户端,
采用的是Yahoo.Yui.Compressor组件还完成的,从这里可下载
创建一个IHttpHandler来处理文件
1 public class CombineFiles : IHttpHandler
2 {
3 private const string CacheKeyFormat = "_CacheKey_{0}_";
4
5 private const bool IsCompress = true; //需要压缩
6
7 public bool IsReusable
8 {
9 get
10 {
11 return false;
12 }
13 }
14
15 public void ProcessRequest(HttpContext context)
16 {
17 HttpRequest request = context.Request;
18 HttpResponse response = context.Response;
19
20 string cachekey = string.Empty;
21
22 string type = request.QueryString["type"];
23 if (!string.IsNullOrEmpty(type) && (type == "css" || type == "js"))
24 {
25 if (type == "js")
26 {
27 response.ContentType = "text/javascript";
28
29 }
30 else if (type == "css")
31 {
32 response.ContentType = "text/css";
33 }
34
35 cachekey = string.Format(CacheKeyFormat, type);
36
37 CompressCacheItem cacheItem = HttpRuntime.Cache[cachekey] as CompressCacheItem;
38 if (cacheItem == null)
39 {
40 string content = string.Empty;
41 string path = context.Server.MapPath("");
42 //找到这个目录下所有的js或css文件,当然也可以进行配置,需求请求压缩哪些文件
43 //这里就将所的有文件都请求压缩
44 string[] files = Directory.GetFiles(path, "*." + type);
45 StringBuilder sb = new StringBuilder();
46 foreach (string fileName in files)
47 {
48 if (File.Exists(fileName))
49 {
50 string readstr = File.ReadAllText(fileName, Encoding.UTF8);
51 sb.Append(readstr);
52 }
53 }
54
55 content = sb.ToString();
56
57 // 开始压缩文件
58 if (IsCompress)
59 {
60 if (type.Equals("js"))
61 {
62 content = JavaScriptCompressor.Compress(content);
63 }
64 else if (type.Equals("css"))
65 {
66 content = CssCompressor.Compress(content);
67 }
68 }
69
70 //输入到客户端还可以进行Gzip压缩 ,这里就省略了
71
72 cacheItem = new CompressCacheItem() { Type = type, Content = content, Expires = DateTime.Now.AddDays() };
73 HttpRuntime.Cache.Insert(cachekey, cacheItem, null, cacheItem.Expires, TimeSpan.Zero);
74 }
75
76 string ifModifiedSince = request.Headers["If-Modified-Since"];
77 if (!string.IsNullOrEmpty(ifModifiedSince)
78 && TimeSpan.FromTicks(cacheItem.Expires.Ticks - DateTime.Parse(ifModifiedSince).Ticks).Seconds < )
79 {
80 response.StatusCode = (int)System.Net.HttpStatusCode.NotModified;
81 response.StatusDescription = "Not Modified";
82 }
83 else
84 {
85 response.Write(cacheItem.Content);
86 SetClientCaching(response, cacheItem.Expires);
87 }
88 }
89
90 }
91
92 private void SetClientCaching(HttpResponse response, DateTime expires)
93 {
94 response.Cache.SetETag(DateTime.Now.Ticks.ToString());
95 response.Cache.SetLastModified(DateTime.Now);
96
97 //public 以指定响应能由客户端和共享(代理)缓存进行缓存。
98 response.Cache.SetCacheability(HttpCacheability.Public);
99
//是允许文档在被视为陈旧之前存在的最长绝对时间。
response.Cache.SetMaxAge(TimeSpan.FromTicks(expires.Ticks));
response.Cache.SetSlidingExpiration(true);
}
private class CompressCacheItem
{
/// <summary>
/// 类型 js 或 css
/// </summary>
public string Type { get; set; } // js css
/// <summary>
/// 内容
/// </summary>
public string Content { set; get; }
/// <summary>
/// 过期时间
/// </summary>
public DateTime Expires { set; get; }
}
} http://www.cnblogs.com/benwu/archive/2012/11/09/2762857.html
Asp.net 程序优化js,css合并与压缩的更多相关文章
- Google Pagespeed,自动压缩优化JS/CSS/Image
Google Pagespeed,自动压缩优化JS/CSS/Image 浏览: 发布日期:// 分类:技术分享 关键字: Nginx Appache Pagespeed 自动压缩优化JS/CSS/Im ...
- js文件合并,压缩,缓存,延迟加载
做web前段也有一段时间了,对于web中js文件的加载有些体会想跟大家一起分享一下. 1.首先说说js文件的合并和压缩吧 为了便于集中式管理js的合并和压缩我们创建一个Js.ashx文件来专门处理合并 ...
- Gulp学习指南之CSS合并、压缩与MD5命名及路径替换(转载)
本文转载自: Gulp学习指南之CSS合并.压缩与MD5命名及路径替换
- requireJS中如何用r.js对js进行合并和压缩css文件
我运行的环境是windows+node.js,首先是用npm安装requirejs(全局安装,即使用 'npm install requirejs -g',这样方便在各个目录调用),接着就是下载r.j ...
- [Asp.net Mvc]为js,css静态文件添加版本号
方式一: 思路 string version = ViewBag.Version; @Scripts.RenderFormat("<script type=\"text/ja ...
- 网站优化JS css压缩
在nginx 中开启gzip压缩后,可以大大减少资js css 体积,原来200KB,压缩后只有66KB server{ gzip on; gzip_types text/plain applicat ...
- gulp入坑系列(2)——初试JS代码合并与压缩
在上一篇里成功安装了gulp到项目中,现在来测试一下gulp的合并与压缩功能 gulp入坑系列(1)--安装gulp(传送门):http://www.cnblogs.com/YuuyaRin/p/61 ...
- gulp学习指南之CSS合并、压缩与MD5命名及路径替换
1.引入插件 var gulp = require('gulp'), // uglify = require('gulp-uglify'), concat = require('gulp-concat ...
- ASP.NET下使用Combres对JS、CSS合并和压缩
记录一下,如何简单快捷压缩js和css,通过合并来减少请求次数. 用到的网址: http://www.nuget.org/packages/combres/ https://github.com/bu ...
随机推荐
- oracle triggers 实现两个结构相同的表的数据级联更新操作
首先创建两个结构相同的表 -- Create table create table TABLE_TEMP ( userid NUMBER not null, username NVARCHAR2(50 ...
- Android AlarmManager的一些问题
我开始的代码是这样写的 alarmManager.set(AlarmManager.RTC_WAKEUP, (5*1000), sender); 我的本意是设定五秒后启动闹钟 但是每次都是我设置完闹钟 ...
- u-boot mkconfig文件分析
#!/bin/sh -e #遇到非0返回 就退出脚本 # Script to create header files and links to configure # U-Boot for a spe ...
- 【转】java图形界面设计(AWT)
[转自]http://blog.sina.com.cn/s/blog_616e189f0100ne1t.html 1. 基本的java Frame操作. Java的图形界面的类主要包括AW ...
- Oracle快速测试连接是否成功
Oracle 客户端建立了TNS连接后,可以快速查看连接是否成功. 1.在cmd中执行命令tnsping orcl(全局数据库名称),即可.以下是命令执行后的示例. 2.如果上一步成功,可以进一步执行 ...
- redis 安装 检测是否安装命令
0: 安装redis服务: # wget http://download.redis.io/releases/redis-3.2.6.tar.gz# tar xzf redis-3.2.6.tar.g ...
- FreeRTOS 低功耗之待机模式
STM32F103 如何进入待机模式在 FreeRTOS 系统中,让 STM32 进入待机模式比较容易,调用固件库函数PWR_EnterSTANDBYMode 即可. STM32F103 如何退出待机 ...
- svn 使用笔记(一)
检出: svn checkout http://***.***.***.*** path --username *** --password *** 更新: svn update path --f ...
- JDK1.6.0+Tomcat6.0的安装配置
JDK1.6.0+Tomcat6.0的安装配置是如何进行的呢?我们按照下面几个步骤来: 1.安装JDK 这是进行JSP开发的重要一步,也是安装JSP引擎(Tomcat.Resin.Weblogic等) ...
- 一款由css3和jquery实现的卡面折叠式菜单
之前已经为大家介绍了好多导航菜单.今天为大家再带来一款由css3和jquery实现的卡片折叠式菜单.当菜单关闭的时候,有三维堆叠的效果.我们一起看下效果图: 在线预览 源码下载 html代码: & ...