0

0

C# MAUI怎么实现文件上传 MAUI上传文件到服务器

畫卷琴夢

畫卷琴夢

发布时间:2025-12-17 14:27:08

|

857人浏览过

|

来源于php中文网

原创

.NET MAUI 文件上传需三步:1. 申请存储读取权限(Android/iOS);2. 用 FilePicker.PickAsync 选文件并读为字节数组;3. 用 HttpClient 构造 MultipartFormDataContent 发送,注意流一次性及前后端字段名、MIME 对齐。

c# maui怎么实现文件上传 maui上传文件到服务器

在 .NET MAUI 中实现文件上传,核心思路是:先用 FilePicker 选中本地文件,读取为字节数组或流,再通过 HttpClient 以 multipart/form-data 方式发送到服务器。MAUI 本身不内置“上传控件”,需手动组合 API 完成。

1. 请求文件访问权限(Android/iOS 平台必需)

尤其在 Android 10+ 和 iOS 上,读取相册、文档等需显式申请权限:

  • Android:在 AndroidManifest.xml 添加 (图片)、READ_MEDIA_FILES(通用)或 READ_EXTERNAL_STORAGE(旧版)
  • iOS:在 Info.plist 添加 NSPhotoLibraryUsageDescription 等描述字段
  • 运行时调用 Permissions.RequestAsync() 获取授权(推荐使用 Microsoft.Maui.Essentials.Permissions

2. 选择文件并读取为流

使用 FilePicker.PickAsync() 获取用户选中的文件,它返回 FileResult,包含可打开的 OpenReadAsync() 流:

var result = await FilePicker.PickAsync(new PickOptions
{
    PickerTitle = "选择要上传的文件",
    FileTypes = FilePickerFileType.Images // 或自定义 MimeType,如 new FilePickerFileType(new Dictionary> { ... })
});

if (result != null)
{
    using var stream = await result.OpenReadAsync();
    // 后续用 stream 构建上传内容
}

3. 使用 HttpClient 发送 multipart 表单上传

服务器通常接收标准 HTML 表单格式(multipart/form-data),需构造 MultipartFormDataContent

var client = new HttpClient();
var content = new MultipartFormDataContent();

// 添加文件流(name 字段需与后端约定,如 "file")
var fileStream = await result.OpenReadAsync();
var fileBytes = await StreamToByteArrayAsync(fileStream); // 辅助方法:读取全部字节
var fileContent = new ByteArrayContent(fileBytes);
fileContent.Headers.ContentType = MediaTypeHeaderValue.Parse(result.ContentType ?? "application/octet-stream");
content.Add(fileContent, "file", result.FileName);

// 可选:添加其他字段,如 token、id
content.Add(new StringContent("123", Encoding.UTF8), "userId");

var response = await client.PostAsync("https://your-api.com/upload", content);
if (response.IsSuccessStatusCode)
{
    var resultJson = await response.Content.ReadAsStringAsync();
}

注意:不要直接传 streamStreamContent 并重复使用——MAUI 的 FileResult.OpenReadAsync() 返回的流是一次性流,且可能已关闭;稳妥做法是先读成 byte[] 或 MemoryStream。

站长俱乐部购物系统
站长俱乐部购物系统

功能介绍:1、模块化的程序设计,使得前台页面设计与程序设计几乎完全分离。在前台页面采用过程调用方法。在修改页面设计时只需要在相应位置调用设计好的过程就可以了。另外,这些过程还提供了不同的调用参数,以实现不同的效果;2、阅读等级功能,可以加密产品,进行收费管理;3、可以完全可视化编辑文章内容,所见即所得;4、无组件上传文件,服务器无需安装任何上传组件,无需支持FSO,即可上传文件。可限制文件上传的类

下载

4. 服务端接收建议(以 ASP.NET Core 为例)

后端需能解析 multipart 请求,例如:

[HttpPost("upload")]
public async Task Upload(IFormFile file)
{
    if (file == null || file.Length == 0)
        return BadRequest("文件为空");

    var uploadsFolder = Path.Combine(Directory.GetCurrentDirectory(), "uploads");
    Directory.CreateDirectory(uploadsFolder);
    var filePath = Path.Combine(uploadsFolder, file.FileName);

    await using var stream = new FileStream(filePath, FileMode.Create);
    await file.CopyToAsync(stream);

    return Ok(new { message = "上传成功", fileName = file.FileName });
}

确保控制器参数名(file)与前端 content.Add(..., "file", ...) 中的 name 一致。

基本上就这些。MAUI 文件上传不复杂但容易忽略权限和流生命周期问题,重点盯住 FileResult.OpenReadAsync() 的一次性行为,以及前后端字段名、MIME 类型是否对齐。

相关专题

更多
html版权符号
html版权符号

html版权符号是“©”,可以在html源文件中直接输入或者从word中复制粘贴过来,php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

616

2023.06.14

html在线编辑器
html在线编辑器

html在线编辑器是用于在线编辑的工具,编辑的内容是基于HTML的文档。它经常被应用于留言板留言、论坛发贴、Blog编写日志或等需要用户输入普通HTML的地方,是Web应用的常用模块之一。php中文网为大家带来了html在线编辑器的相关教程、以及相关文章等内容,供大家免费下载使用。

653

2023.06.21

html网页制作
html网页制作

html网页制作是指使用超文本标记语言来设计和创建网页的过程,html是一种标记语言,它使用标记来描述文档结构和语义,并定义了网页中的各种元素和内容的呈现方式。本专题为大家提供html网页制作的相关的文章、下载、课程内容,供大家免费下载体验。

470

2023.07.31

html空格
html空格

html空格是一种用于在网页中添加间隔和对齐文本的特殊字符,被用于在网页中插入额外的空间,以改变元素之间的排列和对齐方式。本专题为大家提供html空格的相关的文章、下载、课程内容,供大家免费下载体验。

245

2023.08.01

html是什么
html是什么

HTML是一种标准标记语言,用于创建和呈现网页的结构和内容,是互联网发展的基石,为网页开发提供了丰富的功能和灵活性。本专题为大家提供html相关的各种文章、以及下载和课程。

2895

2023.08.11

html字体大小怎么设置
html字体大小怎么设置

在网页设计中,字体大小的选择是至关重要的。合理的字体大小不仅可以提升网页的可读性,还能够影响用户对网页整体布局的感知。php中文网将介绍一些常用的方法和技巧,帮助您在HTML中设置合适的字体大小。

505

2023.08.11

html转txt
html转txt

html转txt的方法有使用文本编辑器、使用在线转换工具和使用Python编程。本专题为大家提供html转txt相关的文章、下载、课程内容,供大家免费下载体验。

312

2023.08.31

html文本框代码怎么写
html文本框代码怎么写

html文本框代码:1、单行文本框【<input type="text" style="height:..;width:..;" />】;2、多行文本框【textarea style=";height:;"></textare】。

425

2023.09.01

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

72

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.7万人学习

CSS教程
CSS教程

共754课时 | 20.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号