解释如何在 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().