asp.net core分块上传文件
写完asp.net多文件上传(http://www.cnblogs.com/bestckk/p/5987383.html)后,感觉这种上传还是有很多缺陷,于是。。。(省略一万字,不废话)。这里我没用传统的asp.net,而选择了开源的asp.net core,原因很简单,.net core是.net新的开始,更是.net和.net开发者的未来,希望.net发展越来越好(大家的工资越来越高(●ˇ∀ˇ●))。
1.前端的实现:
1).html:
- <html>
- <head>
- <meta name="viewport" content="width=device-width" />
- <title>Index</title>
- <link href="/lib/bootstrap/dist/css/bootstrap.css" rel="stylesheet" />
- <script src="/lib/jquery/dist/jquery.js"></script>
- <script src="/lib/bootstrap/dist/js/bootstrap.js"></script>
- <script src="/js/UploadJs.js"></script>
- </head>
- <body>
- <div class="row" style="margin-top:20%">
- <div class="col-lg-4"></div>
- <div class="col-lg-4">
- <input type="text" value="请选择文件" size="20" name="upfile" id="upfile" style="border:1px dotted #ccc">
- <input type="button" value="浏览" onclick="path.click()" style="border:1px solid #ccc;background:#fff">
- <input type="file" id="path" style="display:none" multiple="multiple" onchange="upfile.value=this.value">
- <br />
- <span id="output">0%</span>
- <button type="button" id="file" onclick="UploadStart()" style="border:1px solid #ccc;background:#fff">开始上传</button>
- </div>
- <div class="col-lg-4"></div>
- </div>
- </body>
- </html>
2).javascript:
- var UploadPath = "";
- //开始上传
- function UploadStart() {
- var file = $("#path")[0].files[0];
- AjaxFile(file, 0);
- }
- function AjaxFile(file, i) {
- var name = file.name, //文件名
- size = file.size, //总大小shardSize = 2 * 1024 * 1024,
- shardSize = 2 * 1024 * 1024,//以2MB为一个分片
- shardCount = Math.ceil(size / shardSize); //总片数
- if (i >= shardCount) {
- return;
- }
- //计算每一片的起始与结束位置
- var start = i * shardSize,
- end = Math.min(size, start + shardSize);
- //构造一个表单,FormData是HTML5新增的
- var form = new FormData();
- form.append("data", file.slice(start, end)); //slice方法用于切出文件的一部分
- form.append("lastModified", file.lastModified);
- form.append("fileName", name);
- form.append("total", shardCount); //总片数
- form.append("index", i + 1); //当前是第几片
- UploadPath = file.lastModified
- //Ajax提交文件
- $.ajax({
- url: "/Upload/UploadFile",
- type: "POST",
- data: form,
- async: true, //异步
- processData: false, //很重要,告诉jquery不要对form进行处理
- contentType: false, //很重要,指定为false才能形成正确的Content-Type
- success: function (result) {
- if (result != null) {
- i = result.number++;
- var num = Math.ceil(i * 100 / shardCount);
- $("#output").text(num + '%');
- AjaxFile(file, i);
- if (result.mergeOk) {
- var filepath = $("#path");
- filepath.after(filepath.clone().val(""));
- filepath.remove();//清空input file
- $('#upfile').val('请选择文件');
- alert("success!!!");
- }
- }
- }
- });
- }
这里的主要思路是利用html5 File api的slice方法把文件分块,然后new一个FormData()对象用于储存文件数据,之后就是递归调用AjaxFile方法直至上传完毕。
2.后台C#:
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Threading.Tasks;
- using Microsoft.AspNetCore.Mvc;
- using System.IO;
- // For more information on enabling MVC for empty projects, visit http://go.microsoft.com/fwlink/?LinkID=397860
- namespace DotNet.Upload.Controllers
- {
- public class UploadController : Controller
- {
- // GET: /<controller>/
- public IActionResult Index()
- {
- return View();
- }
- [HttpPost]
- public async Task<ActionResult> UploadFile()
- {
- var data = Request.Form.Files["data"];
- string lastModified = Request.Form["lastModified"].ToString();
- var total = Request.Form["total"];
- var fileName = Request.Form["fileName"];
- var index = Request.Form["index"];
- string temporary = Path.Combine(@"E:\浏览器", lastModified);//临时保存分块的目录
- try
- {
- if (!Directory.Exists(temporary))
- Directory.CreateDirectory(temporary);
- string filePath = Path.Combine(temporary, index.ToString());
- if (!Convert.IsDBNull(data))
- {
- await Task.Run(() => {
- FileStream fs = new FileStream(filePath, FileMode.Create);
- data.CopyTo(fs);
- });
- }
- bool mergeOk = false;
- if (total == index)
- {
- mergeOk = await FileMerge(lastModified, fileName);
- }
- Dictionary<string, object> result = new Dictionary<string, object>();
- result.Add("number", index);
- result.Add("mergeOk", mergeOk);
- return Json(result);
- }
- catch (Exception ex)
- {
- Directory.Delete(temporary);//删除文件夹
- throw ex;
- }
- }
- public async Task<bool> FileMerge(string lastModified,string fileName)
- {
- bool ok = false;
- try
- {
- var temporary = Path.Combine(@"E:\浏览器", lastModified);//临时文件夹
- fileName = Request.Form["fileName"];//文件名
- string fileExt = Path.GetExtension(fileName);//获取文件后缀
- var files = Directory.GetFiles(temporary);//获得下面的所有文件
- var finalPath = Path.Combine(@"E:\浏览器", DateTime.Now.ToString("yyMMddHHmmss") + fileExt);//最终的文件名(demo中保存的是它上传时候的文件名,实际操作肯定不能这样)
- var fs = new FileStream(finalPath, FileMode.Create);
- foreach (var part in files.OrderBy(x => x.Length).ThenBy(x => x))//排一下序,保证从0-N Write
- {
- var bytes = System.IO.File.ReadAllBytes(part);
- await fs.WriteAsync(bytes, , bytes.Length);
- bytes = null;
- System.IO.File.Delete(part);//删除分块
- }
- fs.Close();
- Directory.Delete(temporary);//删除文件夹
- ok = true;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- return ok;
- }
- }
- }
这里的思路就是先保存每一个分块的文件到一个临时文件夹,最后再通过FileStream合并这些临时文件(合并时必需要按顺序)。后台的方法都进行了异步化(async await真的非常好用),虽然不知道对效率有没有提升,但是就是觉得这样很酷。
源码:http://pan.baidu.com/s/1bDdsEa
asp.net core分块上传文件的更多相关文章
- net core分块上传文件
net core分块上传文件 写完asp.net多文件上传(http://www.cnblogs.com/bestckk/p/5987383.html)后,感觉这种上传还是有很多缺陷,于是...( ...
- 一、.Net Core 分块上传文件
一..Net Core 分块上传文件 一.前端实现 @* For more information on enabling MVC for empty projects, visit http://g ...
- 改造kindeditor支持asp.net core mvc上传文件
kindtor默认使用的上传方法是使用目录下面的一般处理程序upload_json.ashx,暂时还不支持asp.net core下的文件上传,下面放出的自定义处理上传文件的接口方法. 自定义接收上传 ...
- ASP.NET Core MVC上传文件
使用模型绑定上传小文件 HTML代码: <form method="post" enctype="multipart/form-data" asp-con ...
- HTML5+AJAX原生分块上传文件的关键参数设置
processData:false 这是jquery.ajax的一个参数.默认值为true,表示会将非字符串对象自动变成k1=v1&k2=v2的形式,例如一个数组参数{d:[1,2]},到服务 ...
- 前端AngularJS后端ASP.NET Web API上传文件
本篇体验使用AngularJS向后端ASP.NET API控制器上传文件. 首先服务端: public class FilesController : ApiController { //usi ...
- asp.net限制了上传文件大小为..M,解决方法
asp.net限制了上传文件大小为4M,在:在web.config里加下面一句,加在<System.web></System.web>之间如下:<system.web&g ...
- ASP.NET Core MVC上传、导入、导出知多少
前言 本君已成夜猫子,本节我们来讲讲ASP.NET Core MVC中的上传,这两天才研究批量导入功能,本节顺便简单搞搞导入.导出,等博主弄妥当了再来和大家一并分享. .NET Core MVC上传 ...
- .NET Core 如何上传文件及处理大文件上传
当你使用IFormFile接口来上传文件的时候,一定要注意,IFormFile会将一个Http请求中的所有文件都读取到服务器内存后,才会触发ASP.NET Core MVC的Controller中的A ...
随机推荐
- 关于VLOOKUP函数的用法
“Lookup”的汉语意思是“查找”,在Excel中与“Lookup”相关的函数有三个:VLOOKUP.HLOOKUO和LOOKUP.下面介绍VLOOKUP函数的用法. 一.功能 在表格的首列查找指定 ...
- codeforces C. Ilya and Matrix 解题报告
题目链接:http://codeforces.com/problemset/problem/313/C 题目意思:给定 4n 个整数(可以组成 2n × 2n 大小的矩阵),问通过对这些整数进行排列, ...
- html5--5-14 阶段小练习:绘制太极图案
html5--5-14 阶段小练习:绘制太极图案 学习要点 运用前几节课的知识完成一个小练习 这个图案有多种不同的绘制方法,这里只做一个简单的演示,练习的时候可以自己思考一下,尝试其他的方法,或者对这 ...
- TCPDUMP 使用详情
第一种是关于类型的关键字,主要包括host,net,port, 例如 host 210.27.48.2,指明 210.27.48.2是一台主机,net 202.0.0.0 指明 202.0.0.0是一 ...
- codevs 1048石子归并
传送门 1048 石子归并 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 有n堆石子排成一列,每堆石子有一个重量w[i], ...
- Python之Numpy详细教程
NumPy - 简介 NumPy 是一个 Python 包. 它代表 “Numeric Python”. 它是一个由多维数组对象和用于处理数组的例程集合组成的库. Numeric,即 NumPy 的前 ...
- Tensorboard 的简单使用
确保环境以及安装好tensorflow以及tensorboard 下面通过一个简单的例子来显示一下使用方式,一个向量加法的图结构. import tensorflow as tf a = tf.con ...
- zabbix snmp、jmx配置使用
SNMP: snmp是很古老的监控,我萌几乎可以在所有设备上看到它的身影 [root@linux-node1 ~]# yum install net-snmp net-snmp-libs net-sn ...
- glance image-create
glance image-create
- json : json数据解析(一)
在项目中经常用到json格式的数据转换与解析,先前写过一些小例子,现在整理下,以备后用和帮助后来者. 言归正传: 使用到的jar包 :json-lib-2.4-jdk15.jar,当然你也可以用自己版 ...