MAUI怎么读写本地文件 MAUI文件系统访问方法

来源:这里教程网 时间:2026-02-21 17:34:12 作者:

MAUI 读写本地文件,核心是用好

Microsoft.Maui.Storage.FileSystem
提供的路径抽象 + .NET 标准异步 I/O 方法。不需为 Android、iOS 或 Windows 单独写路径或申请权限(私有目录下),关键在于选对目录、用对方法、避开常见坑。

用对目录:三种常用存储位置怎么选

MAUI 抽象出几个预定义目录,各司其职:

AppDataDirectory:应用私有、持久化存储首选。适合配置文件、用户数据、数据库文件等。卸载应用时自动清除,无需额外权限。 CacheDirectory:缓存类数据(如网络响应、缩略图)。系统可能在空间不足时自动清理,不适合存关键信息。 TemporaryDirectory:纯临时用途(如解压中转、上传前缓存)。重启或系统清理后可能丢失,不保证保留。

写文件:两步搞定,推荐异步操作

以保存配置为例,写入

AppDataDirectory

拼接完整路径:
Path.Combine(FileSystem.AppDataDirectory, "config.json")
调用标准异步方法:
await File.WriteAllTextAsync(filePath, content)
await File.WriteAllBytesAsync(filePath, data)

注意:不要用

File.WriteAllText
同步版本,会阻塞 UI 线程;路径必须由
FileSystem
提供,不能硬编码(如
"./data/config.txt"
)。

读文件:文本、二进制、资源包文件分别处理

根据文件来源选择读法:

读取自己写入的本地文件:
await File.ReadAllTextAsync(filePath)
(文本)或
await File.ReadAllBytesAsync(filePath)
(二进制)
读取打包进应用的只读资源(如默认配置、模板):
await FileSystem.OpenAppPackageFileAsync("defaults.json")
,返回
Stream
,再用
StreamReader
MemoryStream
处理

不支持直接用

File.OpenRead
读资源包文件,也不建议用
Environment.GetFolderPath
拼路径替代
FileSystem
—— 后者才真正跨平台兼容。

绕过权限崩溃:哪些情况要特别注意

绝大多数场景下,用

AppDataDirectory
CacheDirectory
完全无需声明权限,也不会崩溃。但以下情况需额外处理:

想访问公共目录(如
Downloads
Pictures
):Android 需在
AndroidManifest.xml
声明
READ_EXTERNAL_STORAGE
/
WRITE_EXTERNAL_STORAGE
(Android 10+ 推荐用
Scoped Storage
);iOS 默认禁止,只能通过
FilePicker.PickAsync()
让用户手动选文件
读写外部 SD 卡(Android):需运行时请求权限,且 MAUI 不直接封装该能力,需调用平台特定代码 调试时路径为空?先确认
FileSystem.AppDataDirectory
是否已初始化(通常在
OnStart
或页面加载后可用,非构造函数中)

基本上就这些。用对目录 + 异步 I/O + 资源包专用 API,95% 的本地文件需求都能稳稳落地。

相关推荐