之前的ASP.NET網站,只要把*.html
、*.css
、*.jpg
、*.png
、*.js
等靜態文件放在項目根目錄,默認都可以直接被瀏覽;但ASP.NET Core 小改了瀏覽靜態文件的方式,默認根目錄不再能瀏覽靜態文件,需要指定靜態文件的目錄,才可以被瀏覽。
本篇將介紹ASP.NET Core瀏覽靜態文件的方法。
試着在項目根目錄及wwwroot目錄中加入靜態文件,例如:
項目根目錄\index.html
1
2
3
4
5
6
7
8
9
10
|
<!
DOCTYPE
html>
<
html
>
<
head
>
<
meta
http-equiv="Content-Type" content="text/html; charset=utf-8">
<
title
>MyWebsite</
title
>
</
head
>
<
body
>
項目根目錄的 index.html
</
body
>
</
html
>
|
項目根目錄\wwwroot\index.html
1
2
3
4
5
6
7
8
9
10
|
<!
DOCTYPE
html>
<
html
>
<
head
>
<
meta
http-equiv="Content-Type" content="text/html; charset=utf-8">
<
title
>MyWebsite</
title
>
</
head
>
<
body
>
wwwroot目錄的 index.html
</
body
>
</
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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
// ...
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。如圖:
當Requset的URL文件不存在,則會轉向到Run
的事件(如灰色箭頭)。
變更網站目錄
默認網站目錄是wwwroot,如果想要變更此目錄,可以在Program.cs的WebHost Builder用UseWebRoot
設置網站默認目錄。
例如:把默認網站目錄wwwroot改為public,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
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<Startup>()
.Build();
}
}
|
啟用指定目錄
由於UseStaticFiles
只能拿到默認文件夾底下的文件,某些情況會需要特定目錄也能使用靜態文件。
例如:用npm安裝的第三方庫都放在項目目錄底下的node_modules。
Startup.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
// ...
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
1
2
3
4
5
6
7
8
9
10
|
// ...
public
class
Startup
{
public
void
Configure(IApplicationBuilder app)
{
app.UseDefaultFiles();
app.UseStaticFiles();
// ...
}
}
|
UseDefaultFiles
的職責是嘗試請求默認文件。UseStaticFiles
的職責是回傳請求的文件。
UseDefaultFiles
必須注冊在UseStaticFiles
之前。
如果先注冊UseStaticFiles
,當URL是/時,UseStaticFiles
找不到該文件,就會直接回傳找不到;所以就沒有機會進到UseDefaultFiles
。
自定義默認文件
UseDefaultFiles
的默認文件如下:
- default.htm
- default.html
- index.htm
- index.html
如果默認文件的文件名不在上列清單,也可以自定義要用什么名稱當作默認文件。通過DefaultFilesOptions
設定后,傳入UseDefaultFiles
:
Startup.cs
1
2
3
4
5
6
7
8
9
10
11
12
|
// ...
public
class
Startup
{
public
void
Configure(IApplicationBuilder app)
{
var
defaultFilesOptions =
new
DefaultFilesOptions();
defaultFilesOptions.DefaultFileNames.Add(
"custom.html"
);
app.UseDefaultFiles(defaultFilesOptions);
app.UseStaticFiles();
// ...
}
}
|
文件清單
基本上為了網站安全性考量,不應該讓使用者瀏覽服務器上面的文件清單,但如果真有需求要讓使用者瀏覽文件清單也不是不行。
在Startup.cs的Configure
對IApplicationBuilder
使用UseFileServer
方法注冊文件服務器的功能:
Startup.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
// ...
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\目錄,並且可以直接瀏覽文件目錄及文件內容,如下: