ASP.NET MVC HttpPostedFileBase文件上传的实例代码

本文介绍了ASP.NET MVC HttpPostedFileBase文件上传 ,分享给大家,希望对大家有帮助

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 = 1024 * 4;//4KB
            byte[] buffer = new byte[bufferLen];
            int count = 0;
            while ((count = sourceStream.Read(buffer, 0, bufferLen)) > 0)
            {
              targetStream.Write(buffer, 0, 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 = 0;
              int thumbHeight = 0;
              switch (fileMessage.Mode)
              {
                case "WH": //指定高宽缩放(可能变形)
                  thumbWidth = fileMessage.ThumbWidth.HasValue ? fileMessage.ThumbWidth.Value : 200;
                  thumbHeight = fileMessage.ThumbHeight.HasValue ? fileMessage.ThumbHeight.Value : 200;
                  break;
                case "W":  //指定宽,高按比例
                  thumbWidth = fileMessage.ThumbWidth.HasValue ? fileMessage.ThumbWidth.Value : 200;
                  thumbHeight = height * thumbWidth / width;
                  break;
                case "H":  //指定高,宽按比例
                  thumbHeight = fileMessage.ThumbHeight.HasValue ? fileMessage.ThumbHeight.Value : 200;
                  thumbWidth = width * thumbHeight / height;
                  break;
                default:
                  thumbWidth = fileMessage.ThumbWidth.HasValue ? fileMessage.ThumbWidth.Value : 200;
                  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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • ASP.NET MVC5实现文件上传与地址变化处理(5)

    一.上传文件和重复文件处理 文件处理的原则是:不在数据库中保存文件,只在数据库中保存文件信息(Hash值等).采取文件的MD5重命名文件在一般情况足够处理文件的重复问题,强迫症倾向则可以考虑将MD5和其他摘要算法结合. public static string Save(HttpPostedFileBase file, string path) { var root = "~/Upload/" + path + "/"; var phicyPath = Hostin

  • Asp.net实现MVC处理文件的上传下载功能实例教程

    上传于下载功能是程序设计中非常常见的一个功能,在ASP.NET程序开发中有着非常广泛的应用.本文就以实例形式来实现这一功能. 一.概述 如果你仅仅只有Asp.net Web Forms背景转而学习Asp.net MVC的,我想你的第一个经历或许是那些曾经让你的编程变得愉悦无比的服务端控件都驾鹤西去了.FileUpload就是其中一个,而这个控件的缺席给我们带来一些小问题.这篇文章主要说如何在Asp.net MVC中上传文件,然后如何再从服务器中把上传过的文件下载下来. 二.实现方法 1.文件上传

  • ASP.NET MVC 文件上传教程(一)

    这一节我们来讲讲在MVC中如何进行文件的上传,我们逐步深入,一起来看看. Upload File(一) 我们在默认创建的项目中的Home控制器下添加如下: public ActionResult UploadFile() { return View(); } [HttpPost] public ActionResult UploadFile(HttpPostedFileBase file) { var fileName = file.FileName; var filePath = Server

  • asp.net mvc 实现文件上传带进度条的思路与方法

    前言 文件上传与下载的操作在实际项目中经常是很重要的一个内容,在使用ASP.NET Web Form的时候我们可以使用诸多的服务器控件,FileIpload就是其中之一,但是在ASP.NET不建议使用那些服务器控件,因为那样违反三层架构原则.最近参考网络资料,学习了ASP.NET MVC如何上传文件. 而这篇文章主要重点是asp.net mvc 实现文件上传带进度条,下面来一起看看吧. 实现思路 ajax异步上传文件,且开始上传文件的时候启动轮询来实时获取文件上传进度.保存进度我采用的是memc

  • asp.net中MVC借助Iframe实现无刷新上传文件实例

    本文实例讲述了asp.net中MVC借助Iframe实现无刷新上传文件的方法.分享给大家供大家参考.具体实现方法如下: html: 复制代码 代码如下: <div id="uploadwindow" style="display: none;">     <form action="/ShopActivitys/ImportActivityItems" id="form1" name="form1&

  • ASP.NET MVC4 利用uploadify.js多文件上传

    页面代码: 1.引入js和css文件 <link href="~/Scripts/uploadify/uploadify.css" rel="external nofollow" rel="stylesheet" /> <style type="text/css"> #upDiv { width: 550px; height: 400px; border: 2px solid red; margin-t

  • 用Html5与Asp.net MVC上传多个文件的实现代码

    复制代码 代码如下: <form action="/Home/Upload" enctype="multipart/form-data" id="form2" method="post"> <input type="file" name="fileToUpload" id="fileToUpload2" multiple="multiple

  • ASP.NET MVC处理文件上传的小例子

    复制代码 代码如下: <asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server"> <h2>Files uploaded to server</h2> <div id="dialog" title="Upload files"> <% using (Html.B

  • ASP.NET MVC文件上传教程(二)

    上文ASP.NET MVC 文件上传教程(一)我们讲了简单的上传以及需要注意的地方,查相关资料时,感觉上传里面涉及到的内容还是比较多,于是就将上传这一块分为几节来处理,同时后续也会讲到关于做上传时遗漏的C#应该注意的地方,及时进行查漏补缺,尽量将这一块完善起来. 引入 上一节我们讲到了上传这一块,有朋友提出未涉及到大文件的上传这一块,思前想后还是来试着做做,毕竟之前没怎么去仔细考虑过这个问题,尤其还可以联系实际开发中创建文件夹等一系列问题,同时关于上传在网上随便找找都充斥着大量的组件,我们何必再

  • ASP.NET MVC HttpPostedFileBase文件上传的实例代码

    本文介绍了ASP.NET MVC HttpPostedFileBase文件上传 ,分享给大家,希望对大家有帮助 HttpPostedFileBase文件上传,支持多文件一次上传,如有图片,则支持略缩图保存 文件传输信息封装 /// <summary> /// 文件生成方式 /// </summary> public class UpFileMessage { /// <summary> /// 文件名 /// </summary> public string

  • BootStrap fileinput.js文件上传组件实例代码

    1.首先我们下载好fileinput插件引入插件 <span style="font-size:14px;"><link type="text/css" rel="stylesheet" href="fileinput/css/fileinput.css" rel="external nofollow" /> <script type="text/javascript

  • JS多文件上传的实例代码

    废话不多说了,具体实现代码如下所示: <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <script src="./jquery-1.9.1.min.js"></script> </head> <body> <fo

  • Ajax提交Form表单及文件上传的实例代码

    前几天,发现了一些小问题.我在写后台管理页面时,需要上传一张图片.于是我就用很普通的Form表单上传有一段Json串和图片文件: Form表单上传图片只需要在<form>标签里加上enctype = 'multipart/form-data',这样是可以上传图片的: 但问题来了,在我进行用Form表单提交的时候直接跳出来提交返回值的页面并且原先的页面刷新: 这样我们可以先到异步的Ajax可以实现局部刷新: 废话不多说了 直接上代码: 首先是html: <form id = "f

  • JavaScript Base64 作为文件上传的实例代码解析

    例如我们用某些 裁剪插件 得到的图片是 <img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAAkCAYAAABIdFAMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAHhJREFUeNo8zjsOxCAMBFB/ KEAUFFR0Cbng3nQPw68ArZdAlOZppPFIBhH5EAB8b+Tlt9MYQ6i1BuqFaq1CKSVcxZ2Acs6406

  • commons fileupload实现文件上传的实例代码

    一.文件上传的原理分析 1.文件上传的必要前提 a.表单的method必须是post b.表单的enctype属性必须是multipart/form-data类型的. enctype默认值:application/x-www-form-urlencoded 作用:告知服务器,请求正文的MIME类型 application/x-www-form-urlencoded : username=abc&password=123 ServletRequest.getParameter(String nam

  • springboot 中文件上传下载实例代码

    Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者. Spring Boot特点 1. 创建独立的Spring应用程序 2. 嵌入的Tomcat,无需部署WAR文件 3. 简化Maven配置 4. 自动配置Spr

  • asp.net大文件上传解决方案实例代码

    以ASP.NET Core WebAPI 作后端 API ,用 Vue 构建前端页面,用 Axios 从前端访问后端 API ,包括文件的上传和下载. 准备文件上传的API #region 文件上传 可以带参数 [HttpPost("upload")] public JsonResult uploadProject(IFormFile file, string userId) { if (file != null) { var fileDir = "D:\\aaa"

  • 基于AngularJS的拖拽文件上传的实例代码

    随着HTML5的普及,现在大部分浏览器都支持拖拽功能,今天我们要说的就是实现一套拖拽上传的功能(Angularjs+nodejs). 一.首先前端这款插件是基于AngularJS的,下面我们来看主要代码. 引入js: <script src="js/angular.1.3.15.min.js"></script> <script src="js/ng-file-upload-shim.min.js"></script>

随机推荐