HttpPostedFileBase文件上传,支持多文件一次上传,如有图片,则支持略缩图保存

文件传输信息封装

    /// <summary>
/// 文件生成方式
/// </summary>
public class UpFileMessage
{
/// <summary>
/// 文件名
/// </summary>
public string OriginalFileName { get; set; } /// <summary>
/// 是否保存略缩图
/// </summary>
public bool IsImage { get; set; } /// <summary>
/// 文件流
/// </summary>
public Stream FileStream { get; set; } /// <summary>
/// 生成缩略图的方式
/// [WH]-指定宽高
/// [H]-指定高,按比例缩放宽
/// [W]-指定宽,按比例缩放高
/// </summary>
public string Mode { get; set; } /// <summary>
/// 略缩图高度
/// </summary>
public int? ThumbHeight { get; set; } /// <summary>
/// 略缩图宽度
/// </summary>
public int? ThumbWidth { get; set; } }

文件上传返回结果

   /// <summary>
/// 文件上传返回结果
/// </summary>
public class UpFileResultMessage
{
/// <summary>
/// 文件保存是否成功
/// </summary>
public bool IsSuccess { get; set; } /// <summary>
/// 错误消息
/// </summary>
public string Message { get; set; } /// <summary>
/// 原始文件名-(无扩展名)
/// </summary>
public string FileName { get; set; } /// <summary>
/// 文件名扩展名
/// </summary>
public string FileSuffix { get; set; } /// <summary>
/// 文件名保存路径
/// </summary>
public string FilePath { get; set; } /// <summary>
/// 文件类型为图片时
/// 缩略图保存路径
/// </summary>
public string ThumbPath { get; set; } /// <summary>
/// 保存文件名(无扩展名)
/// </summary>
public string SaveFileName { get; set; } /// <summary>
/// 文件自增ID
/// </summary>
public int[] FileIdArray { get; set; }
}

文件上传类库

需引用System.Web命名空间,并对 [System.Web.UI.Page] 进行继承,调用Server.MapPath方法

 public class FileUtil : System.Web.UI.Page
{
/// <summary>
/// 图片上传
/// </summary>
/// <param name="fileMessage">文件生成方式</param>
/// <returns></returns>
public UpFileResultMessage UpLoadFile(UpFileMessage fileMessage)
{
try
{
string now = DateTime.Today.ToString("yyyyMMdd");
string guid = Guid.NewGuid().ToString(); //获取文件扩展名
var fileSuffix = Path.GetExtension(fileMessage.OriginalFileName); var uploadFolder = Path.Combine(System.Web.HttpContext.Current.Server.MapPath(ParmsConfig.UpFilePathUrl), now); if (!Directory.Exists(uploadFolder))
{
Directory.CreateDirectory(uploadFolder);
} //保存文件名
string saveFileName = guid + fileSuffix;
string filePath = Path.Combine(uploadFolder, saveFileName); UpFileResultMessage upFileResult = new UpFileResultMessage()
{
IsSuccess = true,
FileName = Path.GetFileNameWithoutExtension(fileMessage.OriginalFileName),
FileSuffix = fileSuffix,
FilePath = string.Format(@"{0}/{1}", ParmsConfig.UpFileIPAddressUrl, now),
SaveFileName = guid
}; using (Stream sourceStream = fileMessage.FileStream)
{
using (FileStream targetStream = new FileStream(filePath, FileMode.Create, FileAccess.Write, FileShare.None))
{
const int bufferLen = * ;//4KB
byte[] buffer = new byte[bufferLen];
int count = ;
while ((count = sourceStream.Read(buffer, , bufferLen)) > )
{
targetStream.Write(buffer, , count);
}
}
//上传文件为图片时,需创建缩略图
if (fileMessage.IsImage)
{
var uploadThumbFolder = Path.Combine(uploadFolder, "Thumb"); if (!Directory.Exists(uploadThumbFolder))
{
Directory.CreateDirectory(uploadThumbFolder);
}
using (FileStream targetStream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.None))
{
System.Drawing.Image image = System.Drawing.Image.FromStream(targetStream);
int width = image.Width;
int height = image.Height;
int thumbWidth = ;
int thumbHeight = ;
switch (fileMessage.Mode)
{
case "WH": //指定高宽缩放(可能变形)
thumbWidth = fileMessage.ThumbWidth.HasValue ? fileMessage.ThumbWidth.Value : ;
thumbHeight = fileMessage.ThumbHeight.HasValue ? fileMessage.ThumbHeight.Value : ;
break;
case "W": //指定宽,高按比例
thumbWidth = fileMessage.ThumbWidth.HasValue ? fileMessage.ThumbWidth.Value : ;
thumbHeight = height * thumbWidth / width;
break;
case "H": //指定高,宽按比例
thumbHeight = fileMessage.ThumbHeight.HasValue ? fileMessage.ThumbHeight.Value : ;
thumbWidth = width * thumbHeight / height;
break;
default:
thumbWidth = fileMessage.ThumbWidth.HasValue ? fileMessage.ThumbWidth.Value : ;
thumbHeight = height * thumbWidth / width;
break;
}
string thumbFilePath = Path.Combine(uploadThumbFolder, saveFileName);
CreateThumbnail(thumbFilePath, targetStream, thumbWidth, thumbHeight);
upFileResult.ThumbPath = string.Format(@"{0}/{1}/Thumb", ParmsConfig.UpFileIPAddressUrl, now);
}
}
} return upFileResult;
}
catch (Exception ex)
{
return new UpFileResultMessage() { IsSuccess = false, Message = ex.Message };
} } /// <summary>
/// 创建指定图片文件流的缩略图
/// </summary>
/// <param name="thumbFilePath">缩略图文件保存路径</param>
/// <param name="fileStream">原始文件流</param>
/// <param name="width">缩略图宽</param>
/// <param name="height">缩略图高</param>
private void CreateThumbnail(string thumbFilePath, Stream fileStream, int width, int height)
{
using (Image image = Image.FromStream(fileStream))
{
using (Image thumbnail = image.GetThumbnailImage(width, height, null, IntPtr.Zero))
{
thumbnail.Save(thumbFilePath);
}
} } }

调用方式

  var upFileMsg = new UpFileMessage()
{
IsImage = true,
OriginalFileName = platformImg[i].FileName,
FileStream = platformImg[i].InputStream,
ThumbWidth = ThumbWidth,
Mode = "W"
};
var upFileResultMsg = new FileUtil().UpLoadFile(upFileMsg);

代码地址:文件上传类库包.zip

ASP.NET MVC HttpPostedFileBase文件上传的更多相关文章

  1. MVC图片上传、浏览、删除 ASP.NET MVC之文件上传【一】(八) ASP.NET MVC 图片上传到服务器

    MVC图片上传.浏览.删除   1.存储配置信息 在web.config中,添加配置信息节点 <appSettings> <add key="UploadPath" ...

  2. Asp.net mvc 大文件上传 断点续传

    Asp.net mvc 大文件上传 断点续传 进度条   概述 项目中需要一个上传200M-500M的文件大小的功能,需要断点续传.上传性能稳定.突破asp.net上传限制.一开始看到51CTO上的这 ...

  3. ASP.NET MVC之文件上传【一】(八)

    前言 这一节我们来讲讲在MVC中如何进行文件的上传,我们逐步深入,一起来看看. Upload File(一) 我们在默认创建的项目中的Home控制器下添加如下: public ActionResult ...

  4. ASP.NET MVC之文件上传【一】

    前言 这一节我们来讲讲在MVC中如何进行文件的上传,我们逐步深入,一起来看看. Upload File(一) 我们在默认创建的项目中的Home控制器下添加如下: public ActionResult ...

  5. asp.net mvc 多文件上传

    @{ ViewBag.Title = "多文件上传测试"; } <h2>多文件上传测试</h2> <form action="/Demo/I ...

  6. asp.net mvc下文件上传

    典型的文件上传表单 <form action="/File" enctype="multipart/form-data" method="pos ...

  7. Asp.net mvc 大文件上传 断点续传 进度条

    概述 项目中需要一个上传200M-500M的文件大小的功能,需要断点续传.上传性能稳定.突破asp.net上传限制.一开始看到51CTO上的这篇文章,此方法确实很不错,能够稳定的上传大文件,http: ...

  8. 探索Asp.net mvc 的文件上传

    (转自:http://www.cnblogs.com/n-pei/archive/2010/10/15/1852635.html) 最近因为TeamVideo需要用到视频和图片上传功能,所以试着Goo ...

  9. 探索Asp.net mvc 的文件上传(由浅入深)

    代码下载:http://files.cnblogs.com/n-pei/mvcfileupload.zip 最近因为TeamVideo需要用到视频和图片上传功能,所以试着Google了很多资料,和大家 ...

随机推荐

  1. 最短路径Floyd算法【图文详解】

    Floyd算法 1.定义概览 Floyd-Warshall算法(Floyd-Warshall algorithm)是解决任意两点间的最短路径的一种算法,可以正确处理有向图或负权的最短路径问题,同时也被 ...

  2. iOS开发之资讯类App常用分类控件的封装与实现(CollectionView+Swift3.0+)

    今天博客中,我们就来实现一下一些常用资讯类App中常用的分类选择的控件的封装.本篇博客中没有使用到什么新的技术点,如果非得说用到了什么新的技术点的话,那么勉强的说,用到了一些iOS9以后UIColle ...

  3. CI Weekly #21 | iOS 持续集成快速入门指南

    搭建 iOS 持续集成环境要多久?每个 iOSer 都有不同的答案.这次我们整理了 flow.ci 的 iOS 持续集成的相关文档和最佳实践,希望帮你更快地完成构建.更新文档见: flow.ci iO ...

  4. vue init webpack-simple project 报错处理(connect ETIMEDOUT 192.30.253.112)

    Failed to download repo vuejs-templates/webpack-simple: connect ETIMEDOUT 192.30.253.113:443 Failed ...

  5. [转]AngularJS 之 ng-options指令

    原文地址 一. 基本下拉效果(lable for value in array) 其中select标签中的ng-model属性必须有,其值为选中的对象或属性值. <div ng-controll ...

  6. 摘记:Web应用系统测试内容

    表示层: 内容测试,包括整体审美.字体.色彩.拼写.内容准确性和默认值 Web站点结构,包括无效的链接或图形 用户环境,包括Web浏览器版本和操作系统配置(每一个浏览器都有不同的脚本引擎或虚拟机在客户 ...

  7. 通过 pxe(网络安装)完成centos 系统的网络安装

    首先交代环境.本地2台主机,一台windows主机,一台等待安装centos的主机.2台主机在同一个局域网.通过路由器自动获取ip上网. 网上大多数pxe安装方式都采用自己搭建dns服务器的方式来进行 ...

  8. oracle学习笔记(1)-三级模式SCHEMA

    oracle三级模式及二级映像 模式(schema)是数据库的一个名词,大部分的数据库在结构上都有三级模式的特征,了解下基本的概念,有助于后续深入的学习. 用老罗坚果pro发布会的话说就是,不罗嗦,先 ...

  9. jquery判断按钮是否被选中了

    <script type="text/javascript"> function genjin_view2(elm){ if($(elm).attr("che ...

  10. Canvas画布实现自定义时钟效果

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...