Asp.Net Core入门之静态文件

静态文件( 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

如果通过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 结合了  UseStaticFilesUseDefaultFiles 和  UseDirectoryBrowser (可选)的功能。

例如以下目录层次结构:

  • wwwroot
    • 123.jpg
    • 234.jpg
  • Content
    • images
      • 234.jpg

以下代码启用静态文件、默认文件和及  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/访问时,由于目录下不存在默认文件,所以会打开文件目录。