ASP.NET Core 3.1系列(7)——Controller接收前端上传文件的方法

32 篇文章 39 订阅

1、前言

前一篇博客主要介绍了在GETPOST模式下Controller接收参数的一系列方法,归根结底还是一些简单类型参数的传递和接收。当前端界面需要上传文件时,后台的Controller又应该如何去接收呢?下面开始介绍。

2、搭建前端界面

这里使用LayUI搭建一个简易的前端界面实现多图片上传,代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>上传文件</title>
    <link rel="stylesheet" href="layui/css/layui.css" />
</head>
<body>
    <div class="layui-upload">
        <button type="button" class="layui-btn" id="test">多图片上传</button>
        <div class="layui-upload-list" id="demo2"></div>
    </div>
    <script src="layui/layui.js"></script>
    <script>
        layui.use(['upload', 'element'], function () {
            var $ = layui.jquery;
            var upload = layui.upload;
            var element = layui.element;

            upload.render({
                elem: '#test',
                url: 'https://localhost:5001/api/Home/Upload',
                multiple: true,
                before: function (obj) {
                    //预读本地文件示例,不支持ie8
                    obj.preview(function (index, file, result) {
                        $('#demo2').append('<img src="' + result + '" alt="' + file.name + '" class="layui-upload-img">')
                    });
                },
                done: function (res) {
                    //上传完毕
                },
                allDone: function (obj) {
                    window.alert('上传成功');
                }
            });
        });
    </script>
</body>
</html>

3、后台接收上传文件

新建一个Images文件夹用来存放上传的图片,如下图所示:
在这里插入图片描述

ASP.NET时代,我们一般会用HttpFileCollection来接收文件,而在ASP.NET Core中,我们需要使用另一个接口IFormFileCollection来实现,代码如下:

using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Newtonsoft.Json;
using System;
using System.IO;

namespace App.Controllers
{
    [Route("api/[controller]/[action]")]
    [ApiController]
    public class HomeController : ControllerBase
    {
        private readonly IWebHostEnvironment webHostEnvironment;

        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="webHostEnvironment"></param>
        public HomeController(IWebHostEnvironment webHostEnvironment)
        {
            this.webHostEnvironment = webHostEnvironment;
        }

        /// <summary>
        /// 接收文件
        /// </summary>
        /// <returns></returns>
        [HttpPost]
        public string Upload()
        {
            IFormFileCollection files = Request.Form.Files;
            foreach (IFormFile file in files)
            {
                string directory = Path.Combine(webHostEnvironment.ContentRootPath, "Images");
                string fileExtension = Path.GetExtension(file.FileName);
                string fileName = Guid.NewGuid().ToString() + fileExtension;
                string filePath = Path.Combine(directory, fileName);

                // 生成文件路径
                while (System.IO.File.Exists(filePath))
                {
                    fileName = Guid.NewGuid().ToString() + fileExtension;
                    filePath = Path.Combine(directory, fileName);
                }

                // 写入文件
                using (var stream = new FileStream(filePath, FileMode.Create))
                {
                    file.CopyTo(stream);
                    stream.Flush();
                }
            }
            return JsonConvert.SerializeObject(new
            {
                code = 0,
                msg = "",
                data = ""
            });
        }
    }
}

上面的代码中注入了一个IWebHostEnvironment接口,主要是为了获取Images文件夹的路径,命名文件时采用GUID进行命名,以此确保文件名不会重复。程序运行结果如下图所示:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4、结语

本文主要介绍了ASP.NET CoreController接收文件的方法。上面给出的例子较为简单,在实际开发过程中,可能还需要去判断上传文件的类型、大小等条件,大家可以根据上面的代码自行拓展。

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ASP.NET Core 3.1是一个跨平台、高性能的开源框架,它可以帮助我们快速地构建Web应用程序。ASP.NET Core 3.1中文教程可以为初学者提供一个快速上手的指南,帮助他们了解和掌握该框架的各种功能。 在学习ASP.NET Core 3.1教程之前,我们需要了解一些基本的编程概念和技能, 包括C#语言的基础知识、MVC(Model View Controller)等常见的编程模式、以及前端技术如HTML、CSS和JavaScript等。此外,我们还需要对.NET Core框架有一定的了解,如.NET Core的概念、架构和基础组件等。 学习ASP.NET Core 3.1的教程需要深入理解其设计方案和特点,例如跨平台、高性能、依赖注入、实时通信等。此外,我们还需要熟悉其主要组件,如ASP.NET Core的中间件、MVC框架、Entity Framework Core等。 在学习ASP.NET Core 3.1的教程时,我们需要通过实践才能更好地理解其所涉及的技术和概念。因此,我们需要通过编写各种实际的Web应用程序和示例,来实践和掌握所学的技巧和知识。 总之,学习ASP.NET Core 3.1的中文教程需要较深的前置知识储备和实操经验,而且需要坚持不懈地学习和练习以提高自己的技能水平。 ### 回答2: ASP.NET Core 3.1是目前为止最新的ASP.NET Core版本,它是一个跨平台的Web应用程序开发框架。对于想要学习ASP.NET Core 3.1的开发者来说,中文教程是非常重要的。 现在,有很多中文教程可以帮助开发者快速入门ASP.NET Core 3.1。这些教程通常包括以下内容: 1. ASP.NET Core 3.1的基础知识:网页处理、路由、控制器等; 2. ASP.NET Core 3.1中的模型、视图和控制器; 3. 动作过滤器和特性; 4. 实体框架和数据库相关操作; 5. API设计和测试等。 这些教程通常包含实例和练习,能够帮助开发者深入理解ASP.NET Core 3.1的开发原理。另外,一些知名的在线教育平台,如网易云课堂等,也提供了ASP.NET Core 3.1的中文课程,有兴趣的开发者可以去尝试。 总的来说,学习ASP.NET Core 3.1需要投入时间和精力,但是中文教程能够让初学者更加轻松地掌握ASP.NET Core 3.1的开发技能,更好地进行ASP.NET Core 3.1的开发工作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值