解释如何在 ASP.NET Core 中提供静态文件
静态文件是指无需任何动态计算直接提供给用户的HTML、CSS、JavaScript和图像等内容。
在ASP.NETCore中,Web根目录包含静态文件。默认情况下,它是{contentroot}/wwwroot目录,但您可以使用UseWebRoot()方法更改它。
在Program类中,该CreateDefaultBuilder()方法初始化内容根。
public class Program{
public static void Main(string[] args){
CreateHostBuilder(args).Build().Run();
}
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuilder =>{
webBuilder.UseStartup();
});
} 您可以为应用程序服务的每种类型的文件设置不同的目录。例如,名为css的目录保存样式表,另一个名为js的目录提供应用程序使用的JavaScript,等等。
wwwroot目录中的目录可以通过相对于主机的路径直接访问。例如,如果您将图像存储在wwwroot/pictures目录中,则用户可以从以下URL访问图像:https://
UseStaticFiles()方法中的方法为当前请求路径启用静态文件服务。Startup.Configure()
public void Configure(IApplicationBuilder app, IWebHostEnvironment env){
if (env.IsDevelopment()){
app.UseDeveloperExceptionPage();
}
else{
app.UseExceptionHandler("/Home/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseAuthorization();
app.UseEndpoints(endpoints =>{
endpoints.MapControllerRoute(
name: "default",
pattern: "{controller=Home}/{action=Index}/{id?}");
});
}当您在授权中间件之前调用静态文件中间件时,框架不会对所提供的静态文件执行任何授权检查。因此,wwwroot目录下的文件是可公开访问的。如果要在服务静态文件之前对请求进行授权,则需要将它们存储在wwwroot目录之外,并在调用UseAuthorization().