静态文件(css,js,html等类型文件)通常位于 web根目录下,而ASP.Net Core框架默认内容根目录下的wwwroot
文件夹为web根目录。这里简单解释下内容根目录:实际就是指包含可执行程序exe,程序集dll,配置文件json,xml等的文件目录.
1.访问web根目录静态文件
正常情况下,静态文件是无法直接访问的,需要我们添加如下静态文件的中间件,这是框架内置自带的。
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
app.UseStaticFiles();
}
然后我们就可通过web根目录的相关路径访问静态文件。例如,Web 应用程序项目模板包含 wwwroot 文件夹中的多个文件夹 :
- wwwroot
- css
- images
- js
然后就可以通过如下格式的URL:https://localhost:5001/images/123.jpg 来访问静态文件。
2.访问web根目录之外的静态文件
有些时候,可能有些静态文件我们并不是放在web根目录下面的。例如如下一个目录层次结构,其中要提供的静态文件位于 Web 根目录之外:
- wwwroot
- css
- images
- js
- Content
- images
- img.jpg
- images
如果通过URL:https://localhost:5001/Content/images/img.jpg是无法访问的,这个时候我们就需要额外的指定静态文件路径:
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
//wwroot目录下静态文件
app.UseStaticFiles();
//wwwroot之外的静态文件
app.UseStaticFiles(new StaticFileOptions
{
//指定实际物理路径
FileProvider = new PhysicalFileProvider(Path.Combine(Directory.GetCurrentDirectory(), @"Content/images")),
//设置URL请求的文件路径
RequestPath = new Microsoft.AspNetCore.Http.PathString("/MyStaticFiles")
});
}
然后就可以通过如下格式的URL:https://localhost:5001/MyStaticFiles/img.jpg 来访问静态文件。
3.提供默认文件
UseDefaultFiles中间件用于启用默认文件的功能,例如我们打开一个网站只输入网站地址,就会自动跳出网站首页。这里的网站首页实际就相当于一个默认文件。
ASP.Net Core为我们简化了默认文件的搜索功能,我们只需要添加中间件即可。
public void Configure(IApplicationBuilder app)
{
app.UseDefaultFiles();
app.UseStaticFiles();
}
要提供默认文件,必须在 UseStaticFiles
前调用 UseDefaultFiles
。 UseDefaultFiles
实际上用于重写 URL,不提供文件。 通过 UseStaticFiles
启用静态文件中间件来提供文件。
UseDefaultFiles
默认支持以下几种类型文件:
- default.htm
- default.html
- index.htm
- index.html
当然,框架也支持自定义默认文件,感兴趣的同学可以研究一下。
例如如下一个目录层次结构:
- wwwroot
- Index.html
- css
- images
- js
-
通过URL:https://localhost:5001/访问时,会自动跳转到并打开Index.html页面
4.启用目录浏览功能
出于安全考虑,目录浏览默认处于禁用状态,需通过添加UseDirectoryBrowser中间件的方式开启。
public void Configure(IApplicationBuilder app)
{
//默认文件
app.UseDefaultFiles();
//静态文件
app.UseStaticFiles();
//目录浏览
app.UseDirectoryBrowser();
}
另外,需要注册目录浏览的服务
public void ConfigureServices(IServiceCollection services)
{
services.AddDirectoryBrowser();
}
例如如下一个目录层次结构:
wwwroot
- 123.jpg
- 234.jpg
通过URL:https://localhost:5001/访问时,由于wwwroot根目录下不存在默认文件,所以会打开文件目录。
5.UseFileServer
UseFileServer 结合了 UseStaticFiles
、UseDefaultFiles
和 UseDirectoryBrowser
(可选)的功能。
例如以下目录层次结构:
- wwwroot
- 123.jpg
- 234.jpg
- Content
- images
- 234.jpg
- images
以下代码启用静态文件、默认文件和及 MyStaticFiles
的目录浏览:
public void Configure(IApplicationBuilder app)
{
//静态文件
app.UseStaticFiles();
app.UseFileServer(new FileServerOptions
{
FileProvider = new PhysicalFileProvider(
Path.Combine(Directory.GetCurrentDirectory(), "Content")),
RequestPath = "/MyStaticFiles",
//启用目录
EnableDirectoryBrowsing = true
});
}
EnableDirectoryBrowsing
属性值为 true
时必须注册服务 AddDirectoryBrowser
:
public void ConfigureServices(IServiceCollection services)
{
services.AddDirectoryBrowser();
}
通过URL:https://localhost:5001/MyStaticFiles/访问时,由于目录下不存在默认文件,所以会打开文件目录。