ASP.NET Core WEB API 使用element-ui文件上传组件el-upload执行手动文件文件,并在文件上传后清空文件

简介:

ASP.NET Core WEB API 使用element-ui文件上传组件el-upload执行手动文件文件,并在文件上传后清空文件

目录导航:

前言:
一、简单概述el-upload文件上传组件:
el-upload组件详情,查看官方解释:
常用的基本属性:
二、需要实现的效果:
 三、代码实现:
前端Vue代码实现:
注意,清空已上传的文件列表:
Template代码:
Js中代码:
服务端ASP.NET Core WEB API来进行文件流数据接收和保存:
ASP.NET Core单文件和多文件上传并保存到服务端详情概述:

文章正文:

回到顶部
前言:
从开始学习Vue到使用element-ui-admin已经有将近快两年的时间了,在之前的开发中使用element-ui上传组件el-upload都是直接使用文件选取后立即选择上传,今天刚好做了一个和之前类似的文件选择上传的需求,不过这次是需要手动点击按钮把文件上传到服务器中进行数据导入,而且最多只能够选择一个文件进行上传,上传成功后需要对file-list中的文件列表数据进行清空操作,在这里服务端使用的是ASP.NET Core WEB API来进行文件流数据接收和保存。

回到顶部
一、简单概述el-upload文件上传组件:

el-upload组件详情,查看官方解释:
https://element.eleme.cn/#/zh-CN/component/upload

常用的基本属性:
参数 说明 类型 可选值 默认值
action 必选参数,上传的地址 string — —
headers 设置上传的请求头部 object — —
multiple 是否支持多选文件 boolean — —
data 上传时附带的额外参数 object — —
name 上传的文件字段名 string — file
with-credentials 支持发送 cookie 凭证信息 boolean — false
show-file-list 是否显示已上传文件列表 boolean — true
drag 是否启用拖拽上传 boolean — false
accept 接受上传的文件类型(thumbnail-mode 模式下此参数无效) string — —
on-preview 点击文件列表中已上传的文件时的钩子 function(file) — —
on-remove 文件列表移除文件时的钩子 function(file, fileList) — —
on-success 文件上传成功时的钩子 function(response, file, fileList) — —
on-error 文件上传失败时的钩子 function(err, file, fileList) — —
on-progress 文件上传时的钩子 function(event, file, fileList) — —
on-change 文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用 function(file, fileList) — —
before-upload 上传文件之前的钩子,参数为上传的文件,若返回 false 或者返回 Promise 且被 reject,则停止上传。 function(file) — —
before-remove 删除文件之前的钩子,参数为上传的文件和文件列表,若返回 false 或者返回 Promise 且被 reject,则停止删除。 function(file, fileList) — —
list-type 文件列表的类型 string text/picture/picture-card text
auto-upload 是否在选取文件后立即进行上传 boolean — true
file-list 上传的文件列表, 例如: [{name: 'food.jpg', url: 'https://xxx.cdn.com/xxx.jpg'}] array — []
http-request 覆盖默认的上传行为,可以自定义上传的实现 function — —
disabled 是否禁用 boolean — false
limit 最大允许上传个数 number — —
回到顶部
二、需要实现的效果:
通过单击文件上传按钮,能够弹窗一个Dialog文件选择框,通过点击选取文件按钮选择需要导入的Excel文件,然后手动点击数据导入按钮将Excel文件流通过Post请求传输到ASP.NET Core后台服务中,并进行数据保存操作。

弹出框效果如下图所示:

回到顶部
 三、代码实现:

前端Vue代码实现:

注意,清空已上传的文件列表:
需要ref="upload"和file-list="fileList"这两个属性同时存在,否则即使调用this.$refs.upload.clearFiles();该方法也无效

Template代码:


 <el-dialog title="数据导入" :visible.sync="dialogVisible" width="30%" :before-close="handleClose">
  <el-upload
    class="upload-demo"
    ref="upload"
    :action="actionRequestUrl"
    :on-preview="handlePreview"
    :on-remove="handleRemove"
    :on-success="fileUploadSuccess"
    :on-error="fileUploadFail"
    :on-change="fileChange"
    :file-list="fileList"
    :limit="1"
    :auto-upload="false"
    :headers="headers">
    <el-button slot="trigger" size="small" type="primary">选取文件</el-button>
    <el-button size="small" @click="downloadTemplate">导入模板下载</el-button>
    <div slot="tip" class="el-upload__tip">请按照导入模板中的数据格式导入</div>
  </el-upload>
  <span slot="footer" class="dialog-footer">
    <el-button @click="dialogVisible = false">取 消</el-button>
    <!-- <el-button type="primary" @click="dialogVisible = false">确 定</el-button> -->
    <el-button style="margin-left: 10px;" type="success" @click="submitUpload">数据导入</el-button>
    <!-- <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div> -->
  </span>
</el-dialog>


Js中代码:

return {
  fileList: [], //文件列表
  dialogVisible: false,//Dialog显示状态
  headers: { "X-Token": jwtToken }//设置上传的请求头部
  fileDownloadUrl:'www.xxxx.com',//文件下载地址
  actionRequestUrl:'www.xxxx.com/fileUpload'//请求服务器接口地址
  }},
 //执行相关的方法
 methods: {
 //打开导入弹窗
openImporDialog() {
  this.dialogVisible = true;
},
//关闭弹窗
handleClose() {
  this.dialogVisible = false;
},
//上传到服务器
submitUpload() {
  console.log(this.fileList);
  if (this.fileList.length <= 0) {
    this.$message.error("请先选择需要上传的文件!");
    return false;
  }
  this.$refs.upload.submit();
},
//文件上传服务端失败时的钩子
fileUploadFail: function(err, file, fileList) {
  console.log("文件上传失败", file, fileList);
},
//文件上传服务端成功时的钩子
fileUploadSuccess: function(response, file, fileList) {
  console.log("上传成功");
  console.log(response);
  //清空已上传的文件列表
  this.$refs.upload.clearFiles();
  if (response.result) {
    this.dialogVisible = false;
    this.$message({
      message: response.message,
      type: "success"
    });
  } else {
    this.$message.error(response.message);
  }
},
//文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用
fileChange(file, fileList) {
  //解决无法判断el-upload是否上传过文件问题
  this.fileList = fileList;
  console.log("选择文件上传成功后显示的内容》", file, fileList);
},
//文件列表移除文件时的钩子
handleRemove(file, fileList) {
  this.fileList = [];
  // return this.$confirm(`确定移除 ${file.name}?`);
},
//点击文件列表中已上传的文件时的钩子
handlePreview(file) {
  console.log(file);
},
//导入模板下载
downloadTemplate() {
  window.location.href =this.fileDownloadUrl+"/xxxExcel导入模板.xlsx";
}
}

服务端ASP.NET Core WEB API来进行文件流数据接收和保存:

ASP.NET Core单文件和多文件上传并保存到服务端详情概述:
https://www.cnblogs.com/Can-daydayup/p/12637100.html

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

namespace FileUploadManage.Controllers
{

/// <summary>
/// 图片,视频,音频,文档等相关文件通用上传服务类
/// </summary>
public class FileUploadController : Controller
{
    private static IHostingEnvironment _hostingEnvironment;

    public FileUploadController(IHostingEnvironment hostingEnvironment)
    {
        _hostingEnvironment = hostingEnvironment;
    }

    /// <summary>
    /// Form表单之单文件上传
    /// </summary>
    /// <param name="formFile">form表单文件流信息</param>
    /// <returns></returns>
    public JsonResult FormSingleFileUpload(IFormFile formFile)
    {
        var currentDate = DateTime.Now;
        var webRootPath = _hostingEnvironment.WebRootPath;//>>>相当于HttpContext.Current.Server.MapPath("") 

        try
        {
            var filePath = $"/UploadFile/{currentDate:yyyyMMdd}/";

            //创建每日存储文件夹
            if (!Directory.Exists(webRootPath + filePath))
            {
                Directory.CreateDirectory(webRootPath + filePath);
            }

            if (formFile != null)
            {
                //文件后缀
                var fileExtension = Path.GetExtension(formFile.FileName);//获取文件格式,拓展名

                //判断文件大小
                var fileSize = formFile.Length;

                if (fileSize > 1024 * 1024 * 10) //10M TODO:(1mb=1024X1024b)
                {
                    return new JsonResult(new { isSuccess = false, resultMsg = "上传的文件不能大于10M" });
                }

                //保存的文件名称(以名称和保存时间命名)
                var saveName = formFile.FileName.Substring(0, formFile.FileName.LastIndexOf('.')) + "_" + currentDate.ToString("HHmmss") + fileExtension;

                //文件保存
                using (var fs = System.IO.File.Create(webRootPath + filePath + saveName))
                {
                    formFile.CopyTo(fs);
                    fs.Flush();
                }

                //完整的文件路径
                var completeFilePath = Path.Combine(filePath, saveName);

                return new JsonResult(new { isSuccess = true, returnMsg = "上传成功", completeFilePath = completeFilePath });
            }
            else
            {
                return new JsonResult(new { isSuccess = false, resultMsg = "上传失败,未检测上传的文件信息~" });
            }

        }
        catch (Exception ex)
        {
            return new JsonResult(new { isSuccess = false, resultMsg = "文件保存失败,异常信息为:" + ex.Message });
        }

    }
}

}

作者:追逐时光

原文地址https://www.cnblogs.com/Can-daydayup/p/12676870.html

相关文章
|
3月前
|
开发框架 监控 前端开发
在 ASP.NET Core Web API 中使用操作筛选器统一处理通用操作
【9月更文挑战第27天】操作筛选器是ASP.NET Core MVC和Web API中的一种过滤器,可在操作方法执行前后运行代码,适用于日志记录、性能监控和验证等场景。通过实现`IActionFilter`接口的`OnActionExecuting`和`OnActionExecuted`方法,可以统一处理日志、验证及异常。创建并注册自定义筛选器类,能提升代码的可维护性和复用性。
|
3月前
|
开发框架 .NET 中间件
ASP.NET Core Web 开发浅谈
本文介绍ASP.NET Core,一个轻量级、开源的跨平台框架,专为构建高性能Web应用设计。通过简单步骤,你将学会创建首个Web应用。文章还深入探讨了路由配置、依赖注入及安全性配置等常见问题,并提供了实用示例代码以助于理解与避免错误,帮助开发者更好地掌握ASP.NET Core的核心概念。
111 3
|
3月前
|
开发框架 安全 .NET
Web安全-文件上传漏洞与WAF绕过
Web安全-文件上传漏洞与WAF绕过
205 4
|
4月前
|
开发框架 JavaScript 前端开发
Web Component -- 即将爆发的原生的 UI 组件化标准
Web Component -- 即将爆发的原生的 UI 组件化标准
|
4月前
|
前端开发 安全 开发者
JSF文件上传,让Web应用如虎添翼!一招实现文件上传,让用户爱不释手!
【8月更文挑战第31天】在现代Web应用开发中,文件上传是重要功能之一。JSF(JavaServer Faces)框架提供了强大的文件上传支持,简化了开发流程。本文将介绍JSF文件上传的基本步骤:创建前端表单、处理上传文件的后端Action类、将文件保存到服务器指定目录以及返回结果页面。通过示例代码,我们将展示如何利用JSF实现文件上传功能,包括使用`h:inputFile`控件和`ManagedBean`处理上传逻辑。此外,JSF文件上传还具备类型安全、解耦合和灵活性等优点,有助于提升程序的健壮性和可维护性。
44 0
|
4月前
|
UED 存储 自然语言处理
【语言无界·体验无疆】解锁Vaadin应用全球化秘籍:从代码到文化,让你的应用畅游世界每一个角落!
【8月更文挑战第31天】《国际化与本地化实战:构建多语言支持的Vaadin应用》详细介绍了如何使用Vaadin框架实现应用的国际化和本地化,提升用户体验和市场竞争力。文章涵盖资源文件的创建与管理、消息绑定与动态加载、日期和数字格式化及文化敏感性处理等方面,通过具体示例代码和最佳实践,帮助开发者构建适应不同语言和地区设置的Vaadin应用。通过这些步骤,您的应用将更加灵活,满足全球用户需求。
62 0
|
4月前
|
API 数据库 UED
全面解析构建高性能API的秘诀:运用Entity Framework Core与异步编程提升Web应用响应速度及并发处理能力的详细指南与实践案例
【8月更文挑战第31天】本文详细介绍了如何利用 Entity Framework Core (EF Core)的异步编程特性构建高性能 API。通过创建基于 EF Core 的 .NET Core Web API 项目,配置数据库上下文,并定义领域模型,文章展示了如何使用异步方法进行数据查询、加载相关实体及事务处理。具体代码示例涵盖了 GET、POST、PUT 和 DELETE 操作,全面展示了 EF Core 异步编程的优势,有助于提升 API 的响应速度和处理能力。
59 0
|
4月前
|
数据可视化 Python
通过python建立一个web服务查看服务器上的文本、图片、视频等文件
通过python建立一个web服务查看服务器上的文本、图片、视频等文件
78 0
|
3月前
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
48 7
下一篇
DataWorks