0

0

C#组合文件提供程序 C# CompositeFileProvider如何合并多个文件源

畫卷琴夢

畫卷琴夢

发布时间:2026-02-21 10:20:03

|

204人浏览过

|

来源于php中文网

原创

compositefileprovider 是用于组合多个 ifileprovider 实例以统一访问的协调器,适用于需整合物理路径、嵌入资源和内存文件的场景;按添加顺序依次查找,同名文件仅返回首个匹配项。

c#组合文件提供程序 c# compositefileprovider如何合并多个文件源

CompositeFileProvider 是什么,什么时候该用它

它不是用来“打包文件”的工具,而是让多个 IFileProvider 实例像一个统一目录那样被访问的组合器。典型场景是:你有本地磁盘路径、嵌入资源、甚至内存中生成的文件,想统一用 IWebHostEnvironment.WebRootFileProvider 或 MVC 的视图查找逻辑去读取——这时才需要 CompositeFileProvider

常见错误现象:GetDirectoryContents 返回空、GetFileInfo 找不到嵌入资源、静态文件中间件 404 却确定文件存在。

  • 它不改变文件内容,也不做路径映射或重写
  • 查找顺序严格按添加顺序:先查第一个 provider,没找到再查第二个,以此类推
  • 如果多个 provider 都有同名文件(比如 logo.png),只会返回第一个匹配到的结果

怎么构造 CompositeFileProvider 并注入到 ASP.NET Core 服务中

核心是把多个 IFileProvider 实例传给 CompositeFileProvider 构造函数,然后替换掉默认的 WebRootFileProvider 或注册为自定义 service。

示例:合并 wwwroot + 嵌入资源 + 内存文件

var composite = new CompositeFileProvider(
    new PhysicalFileProvider("wwwroot"),
    new EmbeddedFileProvider(typeof(Program).Assembly, "MyApp.Resources"),
    new MemoryFileProvider()
);

注入方式(.NET 6+):

SauceNAO
SauceNAO

SauceNAO是一个专注于动漫领域的以图搜图工具

下载
  • 替换 WebRoot:在 Program.cs 中调用 builder.Services.AddSingleton<ifileprovider>(composite)</ifileprovider>,但注意这会影响整个 IWebHostEnvironment.WebRootFileProvider
  • 单独注册:用 builder.Services.AddSingleton<ifileprovider>("MyComposite", sp => composite)</ifileprovider>,后续手动从 DI 获取
  • 别直接替换 IHostingEnvironmentIWebHostEnvironmentContentRootFileProvider,它通常不应被覆盖

嵌入资源路径和物理路径混用时的坑

EmbeddedFileProvider 的基路径必须和程序集内嵌资源的命名空间前缀完全匹配,否则 GetFileInfo("style.css") 会返回 Exists == false

常见错误现象:嵌入资源明明存在,但 GetDirectoryContents("") 返回空枚举;或者路径带斜杠时行为异常。

  • 确认资源是否标记为 EmbeddedResource(csproj 中 <embeddedresource include="Resources\style.css"></embeddedresource>
  • EmbeddedFileProvider 第二个参数是命名空间前缀,不是文件夹路径,比如资源实际路径是 MyApp.Resources.style.css,就填 "MyApp.Resources"
  • 物理路径要用正斜杠或反斜杠都行,但嵌入资源路径必须用正斜杠("css/app.css"),哪怕你在 Windows 上开发
  • CompositeFileProvider 不会帮你做大小写归一化,Linux 下嵌入资源名大小写敏感,别依赖首字母大写自动匹配

MemoryFileProvider 和热更新配合的注意事项

它适合运行时动态提供文件(如 CMS 编辑后预览),但默认不支持监听变更,Watch 方法返回空 IChangeToken,所以不能用于触发视图重新编译或静态文件缓存刷新。

如果你需要“改了内存里的文件就立刻生效”,得自己实现带通知机制的 IFileProvider,或者绕过 CompositeFileProvider 单独处理。

  • MemoryFileProvider 的文件内容是只读快照,修改字节数组不会自动同步到 provider
  • 往里面加新文件要用 WriteTextAsync 或直接操作其内部 Files 字典(不推荐,线程不安全)
  • 和其他 provider 组合时,它的优先级由添加顺序决定——放太前面可能导致物理文件被“遮蔽”

最常被忽略的一点:CompositeFileProvider 本身不持有任何文件生命周期控制权,所有底层 provider 的释放(比如 PhysicalFileProvider 的文件句柄)仍需各自负责,别以为组合之后能自动 Dispose。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

180

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

224

2025.12.18

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

695

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1207

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1150

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

822

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

460

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2361

2023.08.08

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

796

2026.02.13

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.9万人学习

C 教程
C 教程

共75课时 | 4.9万人学习

C++教程
C++教程

共115课时 | 18.7万人学习

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

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