ASP.NET Core 2 学习笔记(五)静态文件

之前的ASP.NET网站,只要把.html、.css、.jpg、.png、*.js等静态文件放在项目根目录,默认都可以直接被浏览;但ASP.NET Core 小改了浏览静态文件的方式,默认根目录不再能浏览静态文件,需要指定静态文件的目录,才可以被浏览。
本篇将介绍ASP.NET Core浏览静态文件的方法。

试着在项目根目录及wwwroot目录中加入静态文件,例如:

项目根目录\index.html





    
    MyWebsite


    项目根目录的 index.html


项目根目录\wwwroot\index.html





    
    MyWebsite


    wwwroot目录的 index.html


然后在网址栏输入:
http://localhost:5000/index.html
http://localhost:5000/wwwroot/index.html
会发现以上两个链接都没有办法打开index.html。

浏览静态文件,需要Microsoft.AspNetCore.StaticFiles中间件,ASP.NET Core 2.0以上版本默认包含。

启用静态文件

在Startup.cs的Configure对IApplicationBuilder使用UseStaticFiles方法注册静态文件的Middleware:

Startup.cs


// ...

public class Startup

{

    public void Configure(IApplicationBuilder app)

    {

        app.UseStaticFiles();

 

        // ...

         

        app.Run(async context =>

        {

            await context.Response.WriteAsync("Hello World! \r\n");

        });

    }

}

UseStaticFiles默认启用静态文件的目录是wwwroot,设定完成后再次尝试开启URL:
http://localhost:5000/index.html
开启的内容会是:wwwroot目录的index.html。
http://localhost:5000/wwwroot/index.html
依然无法显示静态文件。

UseStaticFiles注册的顺序可以在外层一点,比较不会经过太多不必要的Middleware。如图:


1215970-20180525102239192-1610780912.png

当Requset的URL文件不存在,则会转向到Run的事件(如灰色箭头)。

变更网站目录

默认网站目录是wwwroot,如果想要变更此目录,可以在Program.cs的WebHost Builder用UseWebRoot设置网站默认目录。
例如:把默认网站目录wwwroot改为public,如下:


using Microsoft.AspNetCore;
using Microsoft.AspNetCore.Hosting;
namespace MyWebsite
{
    public class Program
    {
        public static void Main(string[] args)
        {
            BuildWebHost(args).Run();
        }

 

        public static IWebHost BuildWebHost(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
                .UseWebRoot("public")
                .UseStartup()
                .Build();
    }
}

启用指定目录

由于UseStaticFiles只能拿到默认文件夹底下的文件,某些情况会需要特定目录也能使用静态文件。
例如:用npm安装的第三方库都放在项目目录底下的node_modules。
Startup.cs


// ...

public class Startup

{

    public void Configure(IApplicationBuilder app, IHostingEnvironment env)

    {

        app.UseStaticFiles();

        app.UseStaticFiles(new StaticFileOptions()

        {

            FileProvider = new PhysicalFileProvider(

                Path.Combine(env.ContentRootPath, @"node_modules")),

            RequestPath = new PathString("/third-party")

        });

        // ...

    }

}

以上设定就会把URL http://localhost:5000/third-party/example.js指向到项目目录\node_modules\example.js。

默认文件

比较友好的用户体验会希望http://localhost:5000/可以自动指向到index.html。
能通过UseDefaultFiles设定静态文件目录的默认文件。

Startup.cs

public class Startup
{
    public void Configure(IApplicationBuilder app)
    {
        app.UseDefaultFiles();
        app.UseStaticFiles();
        // ...
    }
} 

文件清单

基本上为了网站安全性考量,不应该让使用者浏览服务器上面的文件清单,但如果真有需求要让使用者浏览文件清单也不是不行。

在Startup.cs的Configure对IApplicationBuilder使用UseFileServer方法注册文件服务器的功能:

Startup.cs


public class Startup
{
    // ...
    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
    {
        app.UseFileServer(new FileServerOptions()
        {
            FileProvider = new PhysicalFileProvider(
                Path.Combine(env.ContentRootPath, @"bin")
            ),

           RequestPath = new PathString("/StaticFiles"),
            EnableDirectoryBrowsing = true
        });
    }
}

当打开http://localhost:5000/StaticFiles时,就指向到项目目录\bin\目录,并且可以直接浏览文件目录及文件内容,如下:

1215970-20180525105908716-32175530.png

参考

Working with static files in ASP.NET Core

你可能感兴趣的:(ASP.NET Core 2 学习笔记(五)静态文件)