在ASP.NET Core应用中,静态文件比如图片、CSS、JS等资源默认不会直接被外部访问,需要通过配置中间件开放访问权限,其中UseStaticFiles就是专门用于处理静态文件访问的核心中间件。

UseStaticFiles基础配置
首先需要在程序启动时注册静态文件中间件,默认情况下,ASP.NET Core会将项目根目录下的wwwroot文件夹作为静态文件的根目录,配置方式非常简单。
在Program.cs文件中,添加如下代码即可开启默认静态文件访问:
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
// 启用默认静态文件中间件,默认访问wwwroot目录下的文件
app.UseStaticFiles();
app.MapGet("/", () => "Hello World!");
app.Run();
此时如果将图片test.jpg放到项目的wwwroot目录下,就可以通过http://localhost:端口号/test.jpg直接访问该图片。
自定义本地图片目录配置
如果希望将本地其他目录作为静态文件目录,比如项目根目录下的LocalImages文件夹,就需要使用StaticFileOptions来指定自定义路径。
首先需要在项目根目录下创建LocalImages文件夹,然后放入需要访问的本地图片,之后修改Program.cs的配置:
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
// 配置自定义静态文件目录,指向本地LocalImages文件夹
var staticFilePath = Path.Combine(builder.Environment.ContentRootPath, "LocalImages");
// 如果目录不存在则创建
if (!Directory.Exists(staticFilePath))
{
Directory.CreateDirectory(staticFilePath);
}
app.UseStaticFiles(new StaticFileOptions
{
// 指定静态文件目录的物理路径
FileProvider = new PhysicalFileProvider(staticFilePath),
// 指定访问该目录的请求路径前缀
RequestPath = "/local-images"
});
app.MapGet("/", () => "Hello World!");
app.Run();
配置完成后,假设LocalImages目录下有demo.png图片,就可以通过http://localhost:端口号/local-images/demo.png访问到该本地图片。
注意事项
- 使用自定义目录时,需要确保目录的物理路径正确,
ContentRootPath是项目的根目录路径,根据需求拼接即可。 - 如果同时需要访问默认的
wwwroot目录和自定义目录,可以多次调用UseStaticFiles方法,分别配置不同的目录。 - 静态文件中间件需要放在路由中间件之前,否则可能会出现访问不到的情况。
同时配置多个静态目录示例
如果需要同时开放wwwroot和自定义的LocalImages目录,代码如下:
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
// 先启用默认wwwroot目录的静态文件访问
app.UseStaticFiles();
// 再启用自定义LocalImages目录的静态文件访问
var staticFilePath = Path.Combine(builder.Environment.ContentRootPath, "LocalImages");
if (!Directory.Exists(staticFilePath))
{
Directory.CreateDirectory(staticFilePath);
}
app.UseStaticFiles(new StaticFileOptions
{
FileProvider = new PhysicalFileProvider(staticFilePath),
RequestPath = "/local-images"
});
app.MapGet("/", () => "Hello World!");
app.Run();
这样配置后,两个目录下的静态资源都可以正常访问,互不冲突。
C#UseStaticFiles静态文件目录本地图片访问修改时间:2026-06-29 11:42:26