开发者社区> 问答> 正文

asp.net 将大图压缩成小图片在首页上显示,为了加快显示速度

首页上显示图片,缩略图,图片在大图的基础上压缩成小图,然后在首页上显示

展开
收起
小旋风柴进 2016-03-12 09:56:57 2451 0
1 条回答
写回答
取消 提交回答
  • 给你一个思路:url重写

    /// 
    /// ResponseImg 的摘要说明
    /// 
    public class ResponseImg : IHttpHandler
    {
    static readonly DateTime Refresh;
    static readonly DateTime Now;
    static ResponseImg()
    {
    Now = DateTime.Now;
    Refresh = Now.AddMonths(1);
    }
    
        public void ProcessRequest(HttpContext context)
        {
    
            if (!string.IsNullOrEmpty(context.Request.Headers["If-Modified-Since"]))
            {
                DateTime IfModifiedSince = DateTime.Parse(context.Request.Headers["If-Modified-Since"]);
                if (IfModifiedSince > Now)
                {
                    context.Response.StatusCode = 304;
                    return;
                }
            }
    
            //string folder = context.Request.QueryString["Folder"];
            string filepath = context.Request.QueryString["FilePath"];
            int width = int.Parse(context.Request.QueryString["Width"]);
            int height = int.Parse(context.Request.QueryString["Height"]);
            string hex = context.Request.QueryString["Hex"];
    
            string path = context.Server.MapPath(string.Format("/QshopImg/{0}", filepath));
    
            byte[] bytes = ImageHelper.Reset(path, width, height);//这个是我写的图片压缩方法 你自己重新上网找
            //System.Drawing.Image img = ImageHelper.Reset(bytes, width, height);
    
            context.Response.Headers["Last-Modified"] = Refresh.ToString();
            //context.Response.Cache.SetExpires(DateTime.Now.Add(Refresh));
            //context.Response.Cache.SetMaxAge(refresh);
            context.Response.Cache.SetCacheability(HttpCacheability.Public);
            context.Response.CacheControl = HttpCacheability.Public.ToString();
            context.Response.Cache.SetValidUntilExpires(true);
            //context.Response.StatusCode = 304;
            //img.Save(context.Response.OutputStream, ImageHelper.GetImageFormat(path));
            context.Response.ContentType = "image/" + hex;
    
            context.Response.BinaryWrite(bytes);
    
        }
    
        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
    
    
    
            <rewrite url="~/(p_img\d{3}/.+?)_(\d{1,3})x(\d{1,3})\.(jpg|jpeg|png|gif|bmp)$"
             to="~/ResponseImg.ashx?FilePath=$1&amp;Width=$2&amp;Height=$3&amp;Hex=$4"/>
                    比如原图片的是/xxx/yyy.png
                    /xxx/yyy_64x64.png 
                    那么就会请求到ResponseImg.ashx 同时把原来的图片压缩成64*64 再输出
    
                    你还可以把压缩后的图片缓存起来,避免再次压缩
    2019-07-17 19:00:13
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载