IFileProvider
File Providers是文件系统之上的一层抽象。它的主要接口是IFileProvider
IFileProvider公开了相应方法用来获取文件信息(IFileInfo), 目录信息(IDirectoryContents),以及设置更改通知(通过使用一个IChangeToken)
- Watch()方法:用来查看一个或多个文件/目录的更改信息。Watch方法接受一个路径字符串,它也可以使用通配符模式来指定多个文件,Watch方法最终返回一个IChangeToken。
IFileInfo
- IFileInfo接口提供了操作单个文件和目录的方法和属性。
- Exists:是否存在
- IsDirectory:是否是目录
- Name:名称
- Length:文件大小(按字节)
- LastModified:最后修改时间
- CreateReadStream():读取文件内容。
IFileProvider的三种实现
PhysicalFileProvider
PhysicalFileProvider提供了对物理文件系统的访问。
当实例化此类provider时,你必须为它提供一个目录路径,作为这个provider发出的所有请求的基础路径(这个provider会限制路径以外的访问请求)
使用方式:直接new实例化PhysicalFileProvider;也可以通过注入IFileProvider的方式使用
方式1:直接new
IFileProvider provider = new PhysicalFileProvider(applicationRoot);
IDirectoryContents contents = provider.GetDirectoryContents(""); // the applicationRoot contents
IFileInfo fileInfo = provider.GetFileInfo("wwwroot/js/site.js"); // a file under applicationRoot
方式2:注入IFileProvider
public void ConfigureServices(IServiceCollection services)
{
// Add framework services.
services.AddMvc();
var physicalProvider = _hostingEnvironment.ContentRootFileProvider;
var embeddedProvider = new EmbeddedFileProvider(Assembly.GetEntryAssembly());
var compositeProvider = new CompositeFileProvider(physicalProvider, embeddedProvider);
// choose one provider to use for the app and register it
//services.AddSingleton<IFileProvider>(physicalProvider);
//services.AddSingleton<IFileProvider>(embeddedProvider);
services.AddSingleton<IFileProvider>(compositeProvider);
}
public class HomeController : Controller
{
private readonly IFileProvider _fileProvider;
public HomeController(IFileProvider fileProvider)
{
_fileProvider = fileProvider;
}
public IActionResult Index()
{
var contents = _fileProvider.GetDirectoryContents("");
return View(contents);
}
}
EmbeddedFileProvider
EmbeddedFileProvider用于访问嵌入到程序集中的文件。
可以将文件的生成操作属性改为"嵌入的资源",来将文件嵌入程序集
创建EmbeddedFileProvider需要传入一个程序集:
var embeddedProvider = new EmbeddedFileProvider(Assembly.GetEntryAssembly());
//EmbeddedFileProvider构造器接受一个可选的baseNamespace参数,指定此参数将限定GetDirectoryContents方法调用该命名空间下的资源
CompositeFileProvider
CompositeFileProvider用于对前两种方式的组合使用。当创建一个CompositeFileProvider时,你可以为它的构造函数传入一个或多个IFileProvider实例。
var physicalProvider = _hostingEnvironment.ContentRootFileProvider;
var embeddedProvider = new EmbeddedFileProvider(Assembly.GetEntryAssembly());
var compositeProvider = new CompositeFileProvider(physicalProvider, embeddedProvider);
通配符模式
*:表示在当前文件夹级别上匹配任何文件名称或文件扩展名
**:表示在多个目录级别上匹配任何文件名称或文件扩展名
案例:
//在指定的文件夹中匹配指定的文件
directory/file.txt
//在指定的文件夹中匹配所有以.txt扩展名结尾的文件
directory/*.txt
//在指定的directory文件夹下的一级目录位置中匹配所有符合project.json名称的文件
directory/*/project.json
//在指定的directory文件夹下的所有位置中匹配所有以.txt扩展名结尾的文件
directory/**/*.txt
参考:
https://www.cnblogs.com/Wddpct/p/6128386.html
https://docs.microsoft.com/en-us/aspnet/core/fundamentals/file-providers?view=aspnetcore-3.1