/// <summary> 
    /// asp.net上传图片并生成缩略图 
    /// </summary> 
    /// <param name="upImage">HtmlInputFile控件</param> 
    /// <param name="sSavePath">保存的路径,些为相对服务器路径的下的文件夹</param> 
    /// <param name="sThumbExtension">缩略图的thumb</param> 
    /// <param name="intThumbWidth">生成缩略图的宽度</param> 
    /// <param name="intThumbHeight">生成缩略图的高度</param> 
    /// <returns>缩略图名称</returns> 
    public string UpLoadImage(FileUpload upImage, string savePath, string sThumbExtension, int intThumbWidth, int intThumbHeight)
    {
        if (upImage.HasFile)
        {
            if (upImage.PostedFile.ContentLength > 0 && upImage.PostedFile.ContentLength / 1024 < 1024)
            {
                string imgType = upImage.PostedFile.ContentType.ToString(); // 图片类型
                if (imgType.Equals("image/pjpeg") || imgType.Equals("image/gif") || imgType.Equals("image/png"))
                {
                    //取得上传文件的扩展名
                    string strExt = upImage.PostedFile.FileName.Substring(upImage.PostedFile.FileName.LastIndexOf("."));
                    // 自定义名称保存
                    string newImaName = (sThumbExtension + strExt).ToString();
                    // 保存到指定目录
                    string newsavePath = Server.MapPath(savePath);

                    System.Drawing.Image img = System.Drawing.Image.FromFile(upImage.PostedFile.FileName);
                    if (img.Width < intThumbWidth && img.Height < intThumbHeight)
                    {
                        return "图片的宽度和高度不符合(" + intThumbWidth + "*" + intThumbHeight+")";
                    }
                    else
                    {
                        upImage.PostedFile.SaveAs(newsavePath + newImaName);
                        return "上传图片成功.";
                    }

                  
                    //try
                    //{
                    //    //原图加载
                    //    using (System.Drawing.Image sourceImage = System.Drawing.Image.FromFile(upImage.PostedFile.FileName))
                    //    {
                    //        //原图宽度和高度
                    //        int width = sourceImage.Width;
                    //        int height = sourceImage.Height;
                    //        int smallWidth;
                    //        int smallHeight;
                    //        //获取第一张绘制图的大小,(比较 原图的宽/缩略图的宽  和 原图的高/缩略图的高)
                    //        if (((decimal)width) / height <= ((decimal)intThumbWidth) / intThumbHeight)
                    //        {
                    //            smallWidth = intThumbWidth;
                    //            smallHeight = intThumbWidth * height / width;
                    //        }
                    //        else
                    //        {
                    //            smallWidth = intThumbHeight * width / height;
                    //            smallHeight = intThumbHeight;
                    //        }

                    //        // 新建一个图板,以最小等比例压缩大小绘制原图
                    //        using (System.Drawing.Image bitmap = new System.Drawing.Bitmap(smallWidth, smallHeight))
                    //        {
                    //            //绘制中间图
                    //            using (System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(bitmap))
                    //            {
                    //                //高清,平滑
                    //                g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High;
                    //                g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;
                    //                g.Clear(Color.Black);
                    //                g.DrawImage(
                    //                    sourceImage,
                    //                    new System.Drawing.Rectangle(0, 0, smallWidth, smallHeight),
                    //                    new System.Drawing.Rectangle(0, 0, width, height),
                    //                    System.Drawing.GraphicsUnit.Pixel);
                    //            }
                    //            //新建一个图板,以缩略图大小绘制中间图
                    //            using (System.Drawing.Image bitmap1 = new System.Drawing.Bitmap(intThumbWidth, intThumbHeight))
                    //            {
                    //                //绘制缩略图
                    //                using (System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(bitmap1))
                    //                {
                    //                    //高清,平滑
                    //                    g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High;
                    //                    g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;
                    //                    g.Clear(Color.Black);
                    //                    int lwidth = (smallWidth - intThumbWidth) / 2;
                    //                    int bheight = (smallHeight - intThumbHeight) / 2;
                    //                    g.DrawImage(bitmap, new Rectangle(0, 0, intThumbWidth, intThumbHeight), lwidth, bheight, intThumbWidth, intThumbHeight, GraphicsUnit.Pixel);
                    //                    g.Dispose();
                    //                    //缩略图保存的绝对路径
                    //                    bitmap1.Save(newsavePath, System.Drawing.Imaging.ImageFormat.Jpeg);
                    //                }
                    //            }
                    //        }

                    //    }
                    //}
                    //catch(Exception ex)
                    //{
                    //   return ex.Message.ToString();
                    //}
                  
                }
                else
                {
                    return "图片类型不正确.";
                }

            }
            else
            {
                return "请选择不大于1M的图片.";
            }
        }
        else
        {
            return "没有选择图片";
        }
    }

.net 图片上传的更多相关文章

  1. Asp.Net Mvc 使用WebUploader 多图片上传

    来博客园有一个月了,哈哈.在这里学到了很多东西.今天也来试着分享一下学到的东西.希望能和大家做朋友共同进步. 最近由于项目需要上传多张图片,对于我这只菜鸟来说,以前上传图片都是直接拖得控件啊,而且还是 ...

  2. 06.LoT.UI 前后台通用框架分解系列之——浮夸的图片上传

    LOT.UI分解系列汇总:http://www.cnblogs.com/dunitian/p/4822808.html#lotui LoT.UI开源地址如下:https://github.com/du ...

  3. JS图片上传预览插件制作(兼容到IE6)

    其实,图片预览功能非常地常见.很意外,之前遇到上传图片的时候都不需要预览,也一直没有去实现过.现在手上的项目又需要有图片预览功能,所以就动手做了一个小插件.在此分享一下思路. 一.实现图片预览的一些方 ...

  4. HTML5笔记:跨域通讯、多线程、本地存储和多图片上传技术

    最近做项目在前端我使用了很多新技术,这些技术有bootstrap.angularjs,不过最让我兴奋的还是使用了HTML5的技术,今天我想总结一些HTML5的技术,好记性不如烂笔头,写写文章可以很好的 ...

  5. 对百度的UEditor多图片上传的一些补充

    我已经写了一篇文章关于百度的UEditor提取多图片上传模块.如果还没有看过,请点击以下链接查看 http://www.cnblogs.com/luke1006/p/3719029.html 出差了两 ...

  6. 使用localResizeIMG3+WebAPI实现手机端图片上传

    前言 惯例~惯例~昨天发表的使用OWIN作为WebAPI的宿主..嗯..有很多人问..是不是缺少了什么 - - 好吧,如果你要把OWIN寄宿在其他的地方...代码如下: namespace Conso ...

  7. TinyMCE的使用(包括汉化及本地图片上传功能)

    TinyMCE我就不多介绍了,这是下载地址:https://www.tinymce.com/download/ 下载下来是英文版,要汉化也很简单.首先去网上随便下载个汉化包,然后把汉化包解压后的lan ...

  8. 包含修改字体,图片上传等功能的文本输入框-Bootstrap

    通过jQuery Bootstrap小插件,框任何一个div转换变成一个富文本编辑框,主要特色: 在Mac和window平台下自动针对常用操作绑定热键 可以拖拽插入图片,支持图片上传(也可以获取移动设 ...

  9. PHP多图片上传实例demo

    upload.html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/ ...

  10. .NET MVC实现多图片上传并附带参数(ajaxfileupload)

    做网站呢,都免不了要做图片上传. 还记得去年做微信的时候用WebAPI+ajaxfileupload.js做了一个能够附带参数上传的功能,博文地址:.NET WebAPI 实现图片上传(包括附带参数上 ...

随机推荐

  1. 在Windows上弄一个redis的docker容器

    [本文出自天外归云的博客园] Docker核心概念简介 镜像是一个面向docker引擎的只读模板,包含了文件系统. 镜像是创建容器的基础,容器类似于一个沙箱,用来运行和隔离应用. 容器是从镜像创建的应 ...

  2. 1:(0or1)

    public class User    {       public int ID { get; set; }       public string UserName { get; set; } ...

  3. 设置定时任务(Timer类的介绍)

    设置定时任务(Timer类的介绍) 在我们的很多项目中,我们都须要用到定时任务,因此想借此博文来对定时任务进行一个介绍. 设置定时任务过程例如以下: 先new一个Timer对象 Timer timer ...

  4. ADO对Excel对象进行连接时的 两种方法区别

    在通过ADO对Excel对象进行连接时(此时Excel则认为是一个数据源),需要配置对Excel数据源对应的连接串,这个连接串中包括了Provider信息(其实类似对数据库进行连接操作时,都需要指定连 ...

  5. html页面布局总结篇

    1. 使用float布局 注意点:使用浮动布局要注意清除浮动.使用伪类清除 浮动层:给元素的float属性赋值后,就是脱离文档流,进行左右浮动,紧贴着父元素(默认为body文本区域)的左右边框. 而此 ...

  6. redis主从配置(docker实现)

    一.docker新建两个redis服务端,并分别设置端口为6379和6380 命令如下: docker run -p : -d --name redis-server docker.io/redis: ...

  7. Lucene整理--索引的建立

    看lucene主页(http://lucene.apache.org/)上眼下lucene已经到4.9.0版本号了, 參考学习的书是依照2.1版本号解说的,写的代码样例是用的3.0.2版本号的,版本号 ...

  8. css限制显示字数,文字长度超出部分用省略号表示【转】

    为了保证页面的整洁美观,在很多的时候,我们常需要隐藏超出长度的文字.这在列表条目,题目,名称等地方常用到. (1).文字超出一行,省略超出部分,显示'...' 如果这种情况比较多,可以取一个切合作用的 ...

  9. FatJar in 创新实训 自然语言交流系统

    Fat Jar Eclipse Plug-In是一个可以将Eclipse JavaProject的所有资源打包进一个可执行jar文件的小工具,可以方便的完成各种打包任务,我们经常会来打jar包,但是e ...

  10. 【转】【WPF】关于依赖属性的ValidateValueCallback,PropertyChangedCallback和CoerceValueCallback的执行顺序

    三个回调对应依赖属性的验证过程,改变过程和强制转换过程. class Dobj : DependencyObject { //依赖属性包装 public int MyProperty { get { ...