使用模型绑定上传小文件

HTML代码:

 <form method="post" enctype="multipart/form-data" asp-controller="Main" asp-action="UploadFiles">
<div class="form-group">
<div class="col-md-10">
<p>使用此表单上传一个或多个文件:</p>
<input type="file" name="files" multiple>
</div>
</div>
8 <div class="form-group">
<div class="col-md-10">
<input type="submit" value="上传">
</div>
</div>
13 </form>
@ViewBag.Message

为支持文件上传,HTML 窗体必须指定 multipart/form-data 的 enctype

form表单的 enctype 属性规定了form表单数据在发送到服务器时候的编码方式

multipart/form-data:指定传输数据为二进制数据,例如图片、mp3、文件

multiple属性规定输入字段可选择多个值(支持批量上传)

上传到服务器的单个文件可使用 IFormFile 接口通过模型绑定进行访问,该接口定义如下:

 public interface IFormFile
{
string ContentType { get; }
string ContentDisposition { get; }
IHeaderDictionary Headers { get; }
long Length { get; }
string Name { get; }
string FileName { get; }
Stream OpenReadStream();
void CopyTo(Stream target);
Task CopyToAsync(Stream target, CancellationToken cancellationToken = null);
}

注意:切勿依赖或信任未经验证的 FileName 属性。 FileName 属性应仅用于显示目的。

在控制器的构造函数中注入 IHostingEnvironment 来获取网站根目录路径:

上传方法:

 public IActionResult UploadFiles(List<IFormFile> files)
{
long size = ;//文件大小
foreach (var file in files)
{
var fileName = file.FileName.Trim('"');//获取文件名
fileName = _hostingEnv.WebRootPath + $@"\{fileName}";//指定文件上传的路径
size += file.Length;
using (FileStream fs = System.IO.File.Create(fileName))//创建文件流
{
file.CopyTo(fs);//将上载文件的内容复制到目标流
fs.Flush();//清除此流的缓冲区并导致将任何缓冲数据写入
}
}
ViewBag.Message = $"{files.Count}个文件 /{size}字节上传成功!";
return View("Index");
17 }

使用 IFormFile 技术上传的文件在处理之前会缓存在内存中或 Web 服务器的磁盘中。 在操作方法中,IFormFile 内容可作为流访问。

运行结果:

在文件的根目录下可以看到上传的2文件:

上传成功!

以上上传功能使用表单提交,以下代码扩展使用Ajax请求提交

 HTML代码:

 <div class="row">
<div class="form-group">
<div class="col-md-10">
<p>上传一个或多个文件:</p>
<input type="file" id="files" name="files" multiple />
</div>
</div>
</div>
<div class="row">
<div class="form-group">
<div class="col-md-10">
<input type="button" id="upload" class="btn btn-success" style="cursor:pointer;" value="上传" />
</div>
</div>
</div>

JavaScript代码:

 $(function () {
$("#upload").click(function () {
var fileUpload = $("#files").get(0);//获得第一个files的名称和值
var files = fileUpload.files;//获取文件信息
var data = new FormData();//通过FormData构造函数创建一个空对象
for (var i = 0; i < files.length; i++) {
data.append(files[i].name, files[i]);//通过append方法追加数据
}
$.ajax({
type: "post",
url: "/Main/UploadFiles",
contentType: false,//不要去设置Content-Type请求头
processData: false,//不要去处理发送的数据
data: data,
success: function (data) {
alert(data.message);
},
error: function () {
alert("上传文件出现错误!");
}
});
});
})

上传方法:

 public IActionResult UploadFiles()
{
long size = ;//文件大小
var files = Request.Form.Files;//获取前端传过来的文件
foreach (var file in files)
{
var fileName = file.FileName.Trim('"');//获取文件名
fileName = _hostingEnv.WebRootPath + $@"\{fileName}";//指定文件上传的路径
size += file.Length;
using (FileStream fs = System.IO.File.Create(fileName))//创建文件流
{
file.CopyTo(fs);//将上载文件的内容复制到目标流
fs.Flush();//清除此流的缓冲区并导致将任何缓冲数据写入
}
}
return Json(new { message = $"{files.Count}个文件 /{size}字节上传成功!" });
17 }

备注:如果文件上传的大小或频率会导致应用出现资源问题,请考虑使用流式处理上传文件。

End!

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

  1. 改造kindeditor支持asp.net core mvc上传文件

    kindtor默认使用的上传方法是使用目录下面的一般处理程序upload_json.ashx,暂时还不支持asp.net core下的文件上传,下面放出的自定义处理上传文件的接口方法. 自定义接收上传 ...

  2. ASP.NET Core MVC上传、导入、导出知多少

    前言 本君已成夜猫子,本节我们来讲讲ASP.NET Core MVC中的上传,这两天才研究批量导入功能,本节顺便简单搞搞导入.导出,等博主弄妥当了再来和大家一并分享. .NET Core MVC上传 ...

  3. asp.net core mvc上传大文件解决方案

    默认上传文件大小不超过30M 第一个问题: IIS 10.0 详细错误 - 404.13 - Not Found 请求筛选模块被配置为拒绝超过请求内容长度的请求. 服务器上的请求筛选被配置为拒绝该请求 ...

  4. asp.net core分块上传文件

    写完asp.net多文件上传(http://www.cnblogs.com/bestckk/p/5987383.html)后,感觉这种上传还是有很多缺陷,于是...(省略一万字,不废话).这里我没用传 ...

  5. asp.net MVC 上传文件 System.Web.HttpException: 超过了最大请求长度

    APS.NET MVC 上传文件出现  System.Web.HttpException: 超过了最大请求长度 这个问题 原因是 默认最大上传文件大小为4096,而我提交的文件太大了. 解决方案:修改 ...

  6. net core分块上传文件

    net core分块上传文件   写完asp.net多文件上传(http://www.cnblogs.com/bestckk/p/5987383.html)后,感觉这种上传还是有很多缺陷,于是...( ...

  7. Spring MVC上传文件

    Spring MVC上传文件 1.Web.xml中加入 <servlet> <servlet-name>springmvc</servlet-name> <s ...

  8. MVC上传文件

    ASP.NET MVC上传文件是必段撑握的知识.加强训练才是.以前Insus.NET曾使用第三方MyAjaxForm.js :http://www.cnblogs.com/insus/p/378548 ...

  9. 一、.Net Core 分块上传文件

    一..Net Core 分块上传文件 一.前端实现 @* For more information on enabling MVC for empty projects, visit http://g ...

随机推荐

  1. OpenGL入门(一):使用GLFW创建简单的窗口

    如果使用QT,那么创建一个OpenGL渲染窗口其实很容易,不过出于初学的角度,使用GLFW库来创建新窗口. 1. 下载并配置GLFW GLFW是一个专门针对OpenGL的C语言库,它提供了一些渲染物体 ...

  2. Java中用import导入类和用Class方法加载类有什么区别?

    import仅仅包含导入操作,并不包含将字节码文件加载进内存这一动作,将字节码文件加载进内存是后续的实例化操作完成的. 例如通过import导入了一堆包和类,但是后续什么都没用(没用实例化),那么导入 ...

  3. 201871010133-赵永军《面向对象程序设计(java)》第七周学习总结

    201871010133-赵永军<面向对象程序设计(java)>第七周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这 ...

  4. LeetCode 113. Path Sum II路径总和 II (C++)

    题目: Given a binary tree and a sum, find all root-to-leaf paths where each path's sum equals the give ...

  5. NOIP 2002 产生数

    洛谷 P1037 产生数 https://www.luogu.org/problemnew/show/P1037 JDOJ 1298: [NOIP2002]产生数 T3 https://neooj.c ...

  6. P256 VRF实现解读

    目录 P256 VRF实现及其改造 公式推导 H1:把任意信息映射到曲线上的点 H2: 映射任意信息为(1,q) 计算随机数 随机数的proof 如何验证 VRF优点 针对S256曲线的改造 1. 使 ...

  7. 【PL/SQL 卡】

    DBA给解决好了,但我不在场,要问一下

  8. 集合 List ,Set

    https://www.cnblogs.com/jmsjh/p/7740123.html

  9. 怎么删除STL容器的元素

    在STL容器有顺序容器和关联容器两种. 顺序容器删除元素的方法有两种: 1.c.erase(p) 从c中删除迭代器p指定的元素.p必须指向c中一个真实元素,不能等于c.end().返回一个指向p之后元 ...

  10. MySQL实战45讲学习笔记:第十七讲

    一 .引子 我在上一篇文章,为你讲解完 order by 语句的几种执行模式后,就想到了之前一个做英语学习 App 的朋友碰到过的一个性能问题.今天这篇文章,我就从这个性能问题说起,和你说说 MySQ ...