一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - Asp.net程序優化js、css實現合并與壓縮的方法

Asp.net程序優化js、css實現合并與壓縮的方法

2019-12-13 09:41shichen2014 ASP.NET教程

這篇文章主要介紹了Asp.net程序優化js、css實現合并與壓縮的方法,使用第三方組件實現訪問時將js與css文件壓縮并緩存在客戶端的效果,非常具有實用價值,需要的朋友可以參考下

本文實例講述了Asp.net程序優化js、css實現合并壓縮的方法。分享給大家供大家參考。具體實現方法如下:

訪問時將js和css壓縮并且緩存在客戶端,
采用的是Yahoo.Yui.Compressor組件來完成的,用戶可以點擊此處本站下載。

創建一個IHttpHandler來處理文件

 

復制代碼代碼如下:


public class CombineFiles : IHttpHandler
{
        private const string CacheKeyFormat = "_CacheKey_{0}_";

 

        private const bool IsCompress = true; //需要壓縮

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }

        public void ProcessRequest(HttpContext context)
        {
            HttpRequest request = context.Request;
            HttpResponse response = context.Response;

            string cachekey = string.Empty;

            string type = request.QueryString["type"];
            if (!string.IsNullOrEmpty(type) && (type == "css" || type == "js"))
            {
                if (type == "js")
                {
                    response.ContentType = "text/javascript";

                }
                else if (type == "css")
                {
                    response.ContentType = "text/css";
                }

                cachekey = string.Format(CacheKeyFormat, type);

                CompressCacheItem cacheItem = HttpRuntime.Cache[cachekey] as CompressCacheItem;
                if (cacheItem == null)
                {
                    string content = string.Empty;
                    string path = context.Server.MapPath("");
                    //找到這個目錄下所有的js或css文件,當然也可以進行配置,需求請求壓縮哪些文件
                    //這里就將所的有文件都請求壓縮
                    string[] files = Directory.GetFiles(path, "*." + type);
                    StringBuilder sb = new StringBuilder();
                    foreach (string fileName in files)
                    {
                        if (File.Exists(fileName))
                        {
                            string readstr = File.ReadAllText(fileName, Encoding.UTF8);
                            sb.Append(readstr);
                        }
                    }

                    content = sb.ToString();

                    // 開始壓縮文件
                    if (IsCompress)
                    {
                        if (type.Equals("js"))
                        {
                            content = JavaScriptCompressor.Compress(content);
                        }
                        else if (type.Equals("css"))
                        {
                            content = CssCompressor.Compress(content);
                        }
                    }

                    //輸入到客戶端還可以進行Gzip壓縮 ,這里就省略了

                    cacheItem = new CompressCacheItem() { Type = type, Content = content, Expires = DateTime.Now.AddDays(30) };
                    HttpRuntime.Cache.Insert(cachekey, cacheItem, null, cacheItem.Expires, TimeSpan.Zero);
                }

                string ifModifiedSince = request.Headers["If-Modified-Since"];
                if (!string.IsNullOrEmpty(ifModifiedSince)
                    && TimeSpan.FromTicks(cacheItem.Expires.Ticks - DateTime.Parse(ifModifiedSince).Ticks).Seconds < 0)
                {
                    response.StatusCode = (int)System.Net.HttpStatusCode.NotModified;
                    response.StatusDescription = "Not Modified";
                }
                else
                {
                    response.Write(cacheItem.Content);
                    SetClientCaching(response, cacheItem.Expires);
                }
            }
        }

        private void SetClientCaching(HttpResponse response, DateTime expires)
        {
            response.Cache.SetETag(DateTime.Now.Ticks.ToString());
            response.Cache.SetLastModified(DateTime.Now);

            //public 以指定響應能由客戶端和共享(代理)緩存進行緩存。    
            response.Cache.SetCacheability(HttpCacheability.Public);

            //是允許文檔在被視為陳舊之前存在的最長絕對時間。 
            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; }
        }
}

 

最后在配置文件中配置一下CombineFiles.axd文件,具體配置略

引用如下

復制代碼代碼如下:
<script type="text/javascript" src="/js/CombineFiles.axd?type=js"></script>
<link rel="stylesheet" type="text/css" href="/css/CombineFiles.axd?type=css" />

 

希望本文所述對大家的asp.net程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产成人精品日本亚洲网址 | 免费看片aⅴ免费大片 | 蜜桃视频在线观看www | aaa一级毛片免费 | 好吊色永久免费视频大全 | 日本精品久久久久中文字幕 1 | 成人免费体验区福利云点播 | 91精品国产综合久久精品 | 四虎免费在线观看 | 99年水嫩漂亮粉嫩在线播放 | 久久视频在线视频观看精品15 | 天天色综 | 人人艹在线视频 | 青青操在线播放 | 7mav视频| 国产在视频线在精品 | 特黄级 | 国产在线观看福利 | 欧美性另类69xxxx | 精品四虎国产在免费观看 | 黑人与欧洲女子性大战 | 操小女人 | 无限在线看免费视频大全 | a男人的天堂久久a毛片 | naruto堂同人本子汉化gg | 天天综合天天影视色香欲俱全 | 国产成人8x视频一区二区 | 午夜一区二区三区 | 日韩永久在线观看免费视频 | 国产rpg迷雾之风冷狐破解 | 五月婷婷丁香色 | 好奇害死猫在线观看 | 国产理论片在线观看 | 久久伊人中文字幕有码 | 99久久精品免费观看区一 | 男女操bb| 扒开放荡老师裙子猛烈的进入 | 91久久精品青青草原伊人 | 视频一本大道香蕉久在线播放 | 美女班主任下面好爽好湿好紧 | 99热精品久久|