.NET生成缩略图并下载

缩略图:比喻一张图片宽度为1000px,大小为800K,经过缩略后变成一张宽度100px,大小10K的图片。

先给出界面:

总体的流程分5步如下图:

1.添加一个html:GetminPic.html

代码:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
</head>
<body>
    <form action="Getmin.ashx" method="post" enctype="multipart/form-data">
        图片:<input type="file" name="file" id="file" onchange="javascript:fileInfo();" />
        <p style="font-size:12px;">原图宽:<label id="ow">0</label>&nbsp;原图高:<label id="oh">0</label>&nbsp;
            原图大小:<label id="os">0</label>KB</p>
      <p>设置宽度:<input type="text" name="width" style="width:50px;"/>
          <span style="color:#09a02c;font-size:12px">高度按原图比例折算</span></p>
       <p><input type="submit" style="color:#ff6a00" value="下载缩略图" /> </p>
    </form>

</body>
</html>
 <script type="text/javascript">
     //上传前获取图片信息(用html5的File)
     function fileInfo() {
         var f = document.getElementById("file").files[0];
         var reader = new FileReader();
         reader.readAsDataURL(f);
         reader.onload = function (e) {
             var data = e.target.result;
             //加载一个图片获取宽度高度
             var image = new Image();
             image.src = data;
             image.onload = function () {
                 var width = image.width;
                 var height = image.height;
                 var size = parseInt(f.size / 1024);
                 document.getElementById("ow").innerHTML = width;
                 document.getElementById("oh").innerHTML = height;
                 document.getElementById("os").innerHTML = size;
             };

         }
     }
    </script>

2.添加一个一般处理程序:Getmin.ashx

代码:

 public void ProcessRequest(HttpContext context)
        {
            //1.获取用户上传的文件流
            HttpPostedFile file = context.Request.Files[0];
            //获取文件名
            string fileName = file.FileName;
            //获取扩展名
            string Extension = Path.GetExtension(fileName).ToUpper();
            //2.根据用户上传的文件流创建一个图片
            using (Image originalImage = Image.FromStream(file.InputStream))
            {
            //获取原始图片的宽和高
                int owidth = originalImage.Width;
                int oheight = originalImage.Height;
                //缩略图的宽
                int mwidth = Convert.ToInt32(context.Request.Form["width"]);
                //等比例的高,取整数
                int mheight = mwidth * oheight / owidth;
                //3.根据原始图片,等比例创建一个缩小后的图片
                using (Image minImage = new Bitmap(mwidth, mheight))
                {
                   //4.把大图片内容画到小图片上
                    //基于小图创建一个画面对象
                    Graphics gmin = Graphics.FromImage(minImage);
                    //把大图画到小图上
                    gmin.DrawImage(originalImage, 0, 0, mwidth, mheight);

                    //5.下载缩略图
                    MemoryStream ms = new MemoryStream();
                    //判断图片类型
                    ImageFormat imageFormat = null;
                    string ContentType = "";
                    switch (Extension)
                    {
                        case ".JPG": imageFormat = ImageFormat.Jpeg; ContentType = "image/jpeg"; break;
                        case ".PNG": imageFormat = ImageFormat.Png; ContentType = "image/png"; break;
                        case ".GIF": imageFormat = ImageFormat.Gif; ContentType = "image/gif"; break;
                        //................如需要其他图片格式继续添加
                    }
                    minImage.Save(ms,imageFormat);
                    context.Response.ClearContent();
                    context.Response.AddHeader("Content-Disposition", "attachment;  filename=" + HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8));
                    context.Response.ContentType=ContentType;
                    context.Response.BinaryWrite(ms.ToArray());
                    context.Response.End();
                }
            }
        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }

代码注释已经很清晰了,所以也不一一解析了。

3.效果

 3.1挑一张计算机里的图片:

3.2上传前:

3.3把宽度设成200后点击下载

3.4查看已经下载的文件

demo下载:http://pan.baidu.com/s/1jHiIXuQ  提取密码:fewx

时间: 2024-10-10 02:43:58

.NET生成缩略图并下载的相关文章

[原创]超强C#图片上传,加水印,自动生成缩略图源代码

<%@ Page Language=“C#“ AutoEventWireup=“true“ %> <%@ Import Namespace=“System“ %> <%@ Import Namespace=“System.IO“ %> <%@ Import Namespace=“System.Net“ %> <%@ Import NameSpace=“System.Web“ %> <%@ Import NameSpace=“Legalsof

使用nginx生成缩略图

nginx中可以使用 --with-http_image_filter_module 这个模块,今天发现在github上发现国人开发的一款模块 模块同时支持 Nginx 和 tengine 本nginx模块主要功能是对请求的图片进行缩略/水印处理,支持文字水印和图片水印.支持自定义字体,文字大小,水印透明度,水印位置.判断原图是否是否大于指定尺寸才处理. ....等等 编译方法 编译前请确认您的系统已经安装了libcurl-dev libgd2-dev libpcre-dev 依赖库 Debia

PHP.25-TP框架商城应用实例-后台1-添加商品功能、钩子函数、在线编辑器、过滤XSS、上传图片并生成缩略图

添加商品功能 1.创建商品控制器[C] /www.test.com/shop/Admin/Controller/GoodsController.class.php <?php namespace Admin\Controller; use Think\Controller; //后台添加商品功能控制器 class GoodsController extends Controller { //显示和处理表单 public function add() { //判断用户是否提交了表单(如果提交了,就

shell脚本获取网页快照并生成缩略图

获取网页快照并生成缩略图可分两步进行: 1.获取网页快照 2.生成缩略图 获取网页快照 这里我们用 phantomjs 来实现.关于 phantomjs 的详细用法可参考 官方网站 . 1.安装 我的环境是CentOS6.5,安装时直接下载 tarball 然后解压即可. # wget https://bitbucket.org/ariya/phantomjs/downloads/phantomjs-1.9.8-linux-i686.tar.bz2 # tar -jxvf phantomjs-1

[转]Phantomjs实现获取网页快照并生成缩略图

Shell脚本实现获取网页快照并生成缩略图 这篇文章主要介绍了Shell脚本实现获取网页快照并生成缩略图,本文获取网页快照使用phantomjs.生成缩略图使用ImageMagick,需要的朋友可以参考下 获取网页快照并生成缩略图可分两步进行: 1.获取网页快照 2.生成缩略图 获取网页快照 这里我们用 phantomjs 来实现.关于 phantomjs 的详细用法可参考官方网站.http://phantomjs.org/ 1.安装 我的环境是CentOS 7,安装时直接下载源码,我下的版本是

Java生成缩略图Thumbnailator(转载)

转自(http://rensanning.iteye.com/blog/1545708) Thumbnailator 是一个为Java界面更流畅的缩略图生成库.从API提供现有的图像文件和图像对象的缩略图中简化了缩略过程,两三行代码就能够从现有图片生成缩略图,且 允许微调缩略图生成,同时保持了需要写入到最低限度的代码量.同时还支持根据一个目录批量生成缩略图. thumbnailator-0.4.8.jar 下载地址:http://files.cnblogs.com/files/haha12/th

C#简单生成缩略图的方法

本文实例讲述了C#简单生成缩略图的方法.分享给大家供大家参考.具体实现方法如下: /// <summary> /// 生成缩略图 /// </summary> /// <param name="originalImagePath">源图路径(物理路径)</param> /// <param name="thumbnailPath">缩略图路径(物理路径)</param> /// <para

nginx实时生成缩略图到硬盘上

原文:http://www.ttlsa.com/nginx/nginx-create-image-on-disk/ 现在随着各终端的出现(手机,ipad等平板),以及各种终端的手机分辨率和尺寸都不同,现在手机用户流量都是宝,网上出现了各种各样的生成缩略图功能的架构,有使用php实时生成缩略图的,也有用nginx + lua实现的,上节我也讲到了使用nginx生成缩略图,但是用户每次访问都需要生成一次,会给cpu和硬盘带来比较大的压力,今天带来了另外一种方式,这次使用nginx将原图生成缩略图到硬

生成缩略图时报GDI+中发生一般性错误

最近由于业务需要要写一个生成缩略图并能设置图片质量的功能,本来这是一件so easy的事,以前也干过,可是却遇到了问题.话不多说先看代码 /// <summary> /// 等比生成缩略图 /// </summary> /// <param name="originalImagePath">源图路径(物理路径)</param> /// <param name="thumbnailPath">缩略图路径(物理