如何在 .NET Core WebApi 中处理 MultipartFormDataContent 中的文件

在上一篇文章(如何在 .NET Core WebApi 中处理 MultipartFormDataContent)中,我们有描述过如何以最简单的方式在 .NET Core WebApi 中处理 MultipartFormDataContent 。基于框架层面的封装,我们可以快速的从 Request.Form 中分别拿到文件内容和文本内容,但是这些默认的解析方式都是建立在前后端以标准的数据格式来进行构建和解析。

问题描述

如何在 .NET Core WebApi 中处理 MultipartFormDataContent 中的文件

上图示例展示了用户通过 IOS 客户端发送请求时,对应后端接口接收到的 Request 内容。从请求内容的整体结果,我们可以看出这是一个 multipart/form-data 的数据格式,由于这种数据是由多个 multipart section 组成,所以我们可以看出在这个请求体中,是包含3个 section ,name 值分别为 Agree,CultureCode,FingerSignature,每个 section 都会包含一个 Content-Disposition 字段,前面两个 section都是普通的数据格式,最后一个是图片类型的数据。当后端接口接收到这样一个请求体时,尝试使用 Request.Form.Files 的方式来获取目标文件时,发现无法获取 FingerSignature 对应的文件内容。

问题分析

通过和客户沟通,了解到FingerSignature 对应的文件是会被一起放到请求体中传给后端,客户表示前端APP这一块的逻辑在后端还没有升级成 ASP.NET Core(处于 Framework 阶段)的时候是可以正常工作的。通过查看ASP.NET Core 中对 Request.Form 的赋值逻辑: FormFeature 实现,找到了如下逻辑函数:

如何在 .NET Core WebApi 中处理 MultipartFormDataContent 中的文件

通过源码的逻辑,我们可以看出,只有当前的 section 对应的 Content-Disposition 同时包含 form-data 和 fileName (或 fileNameStar),才会被作为文件来处理(示例:form-data; name="FingerSignature"; fileName=”xxxx.jpeg”),否则并不会把当起的 Section 添加到 Request.Form.Files 中。此时结合上面获取的请求内容,定位到 FingerSignature 部分的 Content-Disposition 中由于缺少 fileName 字段导致后端无法解析到对应文件为该issue 的 Root Cause。

解决方案

由于前端 APP 已经发布多个版本,所以让前端来补全这个字段显然不是一种稳妥的修复方案,因此后端需要做一个兼容性处理。当遇到这种不是标准格式的文件内容,需要通过 MultipartReader 对象来处理 MultipartFormDataContent 对应的 Section 内容(实际上 Request.Form.Files 底层逻辑就是通过 MultipartReader 来依次解析每个 Section 内容)。这里实现了一个方法来获取当前 MultipartFormDataContent 中的所有文件:

如何在 .NET Core WebApi 中处理 MultipartFormDataContent 中的文件

在这个方法中有2个细节地方需要注意。

  • 默认情况下,Request.Body 中的内容只允许读取一次,所以我们需要在使用这个方法的路由地方启用 EnableBuffering 设置,这里可以自定义一个 Filter 来复用这种特性:

如何在 .NET Core WebApi 中处理 MultipartFormDataContent 中的文件

  • 因为对 Request.Body开启 EnableBuffering 了,所以在调用 ReadFilesAsyns 方法的时候,不确定此时 Body 中的 Stream起始位置为 0。所以我们需要在读取 Body 之前和之后通过 Seek 方法将 Stream的 Position 重置归 0。

优化建议

从目前的修复方案来讲的话,后端只是提供了一种妥协的修复方案来适配前端的数据不完整,因此感觉比较完善的修复方案是前端在发送 multipart/form-data 的数据时,尽量以标准的方式来构建每个 Section 内容,尤其是文件类型。如果前后端都能以统一的数据格式来进行交互,自然也就不会出现上述所说的这种问题,潜在的风险自然也就变小了。

原文链接:https://www.cnblogs.com/hippieZhou/archive/2023/04/21/17316146.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:如何在 .NET Core WebApi 中处理 MultipartFormDataContent 中的文件 - Python技术站

(0)
上一篇 2023年4月22日
下一篇 2023年4月22日

相关文章

  • WPF基础教程之元素绑定详解

    让我来为您详细讲解“WPF基础教程之元素绑定详解”的完整攻略。 什么是WPF元素绑定? WPF元素绑定是一种机制,用于在WPF应用程序中将数据绑定到UI元素。它允许我们动态更新界面元素的值,而无需手动更改它们。WPF元素绑定非常强大和灵活,可以应用于几乎所有的UI元素。 元素绑定的基本语法和用法 在WPF中,元素绑定使用花括号”{ }”和绑定路径来实现。以下…

    C# 2023年5月15日
    00
  • 基于C#方法重载的总结详解

    基于C#方法重载的总结详解 在C#中,方法重载(Overloading)允许我们定义多个同名函数,只要它们的参数类型、数量或顺序不同。当我们调用函数时,编译器会根据提供的参数类型、数量和顺序来自动匹配函数。 方法重载的定义和规则 定义方法重载 方法重载需要在同一类中定义,其函数名称必须相同,形参列表不同。形参列表包括参数的数据类型、参数的个数以及参数的排列顺…

    C# 2023年5月15日
    00
  • 在asp.net(c#)下实现调用cmd的方法

    下面来详细讲解在asp.net(c#)下实现调用cmd的方法,包含以下步骤: 步骤一:添加命名空间 using System.Diagnostics; // 引入System.Diagnostics命名空间 Step 2:创建Process类对象 在C#中,Process类用于表示进程并启动进程。首先,我们需要创建一个Process类对象来启动CMD进程。 …

    C# 2023年5月31日
    00
  • asp.net网站底部的版权信息实现代码且可维护

    关于ASP.NET网站底部的版权信息实现代码,一般有两种常见的实现方式,分别是通过ASP.NET Master页和ASP.NET User Control实现。 通过ASP.NET Master页实现 步骤一:创建Master页 在Visual Studio中创建Web应用程序,添加Master Page,并设置该Master Page为网站默认页。在Mas…

    C# 2023年5月31日
    00
  • 实现ASP.NET多文件上传程序代码

    实现ASP.NET多文件上传程序是一个常见的需求,可以通过以下步骤来实现: 页面设计 首先,在ASP.NET页面上添加文件上传控件,代码如下: <div> <asp:Label ID="lblUpload" runat="server" Text="Upload files:"&g…

    C# 2023年5月31日
    00
  • C#自定义基于控制台的Timer实例

    下面就为大家详细讲解如何自定义基于控制台的Timer实例。 准备工作 在使用C#自定义基于控制台的Timer实例之前,我们需要先在命名空间中引用System.Threading命名空间。 using System.Threading; 接着我们需要定义Timer对象和定时器事件处理程序,代码如下: //定义Timer对象 Timer timer = null…

    C# 2023年6月1日
    00
  • 浅谈C# 9.0 新特性之只读属性和记录

    当然,我很愿意为您讲解“浅谈C#9.0新特性之只读属性和记录”的完整攻略。下面是详细的解释。 什么是C# 9.0? C# 是一种由微软推出的面向对象编程语言,其 9.0 版本于 2020 年 11 月发布。C# 9.0 带来了许多新特性和语言改进,使得编写高效、可维护的代码更加容易。 只读属性 只读属性是指,一旦属性被初始化之后,就不能再次赋值。在 C# 9…

    C# 2023年5月15日
    00
  • C# AE之返回上一级和下一级的实战操作

    C# AE之返回上一级和下一级的实战操作 在C# AE(Adobe After Effects)中,返回上一级和下一级的操作非常常见,本文将详细讲解如何实现这个功能。 返回上一级 返回上一级的操作可以通过使用AE的“撤销”(Undo)功能来完成。在C#中,可以通过调用Undo()方法来实现。具体步骤如下: 导入AE的COM组件: using AE = Ado…

    C# 2023年6月7日
    00
合作推广
合作推广
分享本页
返回顶部