ASP.NET Core靜態(tài)文件使用教程(9)
在這一章,我們將學(xué)習(xí)如何使用文件。幾乎每個(gè)web應(yīng)用程序都需要一個(gè)重要特性:能夠從文件系統(tǒng)提供文件(靜態(tài)文件)。
- 靜態(tài)文件像JavaScript文件、圖片、CSS文件等,我們Asp.Net Core應(yīng)用程序可以直接提供給客戶。
- 靜態(tài)文件通常位于web根(wwwroot)文件夾。
- 默認(rèn)情況下,這是我們可以直接從文件系統(tǒng)提供文件的唯一的地方。
案例
現(xiàn)在讓我們通過(guò)一個(gè)簡(jiǎn)單的示例來(lái)了解我們?cè)谖覀兊膽?yīng)用程序如何提供這些靜態(tài)文件。
在這里,我們想要向我們的 FirstAppDemo 應(yīng)用程序添加一個(gè)簡(jiǎn)單的 HTML 文件,該 HTML 文件放在web 根 (wwwroot) 文件夾。在解決方案資源管理器中右鍵單擊wwwroot文件夾并選擇Add→新項(xiàng)。

在中間窗格中,選擇 HTML 頁(yè)面并稱之為 index.html,單擊添加按鈕。

你會(huì)看到一個(gè)簡(jiǎn)單的index.html文件。讓我們?cè)谄渲刑砑右恍┖?jiǎn)單的文本和標(biāo)題如下所示。
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>Welcome to ASP.NET Core</title> </head> <body> Hello, Wolrd! this message is from our first static HTML file. </body> </html>
當(dāng)您運(yùn)行應(yīng)用程序并在瀏覽器中輸入index.html時(shí),您將看到app.Run中間件將拋出一個(gè)異常,因?yàn)槟壳霸谖覀兊膽?yīng)用程序中什么都沒(méi)有。

現(xiàn)在我們的項(xiàng)目中沒(méi)有中間件會(huì)去找文件系統(tǒng)上的任何文件。
為了解決這個(gè)問(wèn)題,通過(guò)在解決方案資源管理器中右鍵單擊您的項(xiàng)目并選擇管理NuGet包進(jìn)入到NuGet包管理器。

搜索 Microsoft.AspNet.StaticFiles,會(huì)找到靜態(tài)文件中間件。讓我們安裝此 nuget 程序包,現(xiàn)在我們可以在Configure方法中注冊(cè)中間件。
讓我們?cè)谙旅娴某绦蛑兴镜腃onfigure方法中添加 UseStaticFiles 中間件。
using Microsoft.AspNet.Builder;
using Microsoft.AspNet.Hosting;
using Microsoft.AspNet.Http;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Configuration;
namespace FirstAppDemo {
public class Startup {
public Startup() {
var builder = new ConfigurationBuilder()
.AddJsonFile("AppSettings.json");
Configuration = builder.Build();
}
public IConfiguration Configuration { get; set; }
// This method gets called by the runtime.
// Use this method to add services to the container.
// For more information on how to configure your application,
// visit http://go.microsoft.com/fwlink/?LinkID=398940
public void ConfigureServices(IServiceCollection services) {
}
// This method gets called by the runtime.
// Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app) {
app.UseIISPlatformHandler();
app.UseDeveloperExceptionPage(); app.UseRuntimeInfoPage();
app.UseStaticFiles();
app.Run(async (context) => {
throw new System.Exception("Throw Exception");
var msg = Configuration["message"];
await context.Response.WriteAsync(msg);
});
}
// Entry point for the application.
public static void Main(string[] args) => WebApplication.Run<Startup>(args);
}
}
除非你通過(guò)傳入一些不同的配置參數(shù)來(lái)覆蓋選項(xiàng),否則靜態(tài)文件會(huì)對(duì)于一個(gè)給定的請(qǐng)求看作是請(qǐng)求路徑。這個(gè)請(qǐng)求路徑是相對(duì)于文件系統(tǒng)。
- 如果靜態(tài)文件根據(jù)url找到一個(gè)文件,它將直接返回該文件,而不調(diào)用下一個(gè)塊中間件。
- 如果沒(méi)有找到匹配的文件,那么它會(huì)繼續(xù)執(zhí)行下一個(gè)塊中間件。
讓我們保存Startup.cs文件并刷新瀏覽器。

你現(xiàn)在可以看到index.html文件。你放置在wwwroot文件夾下任何地方的任何JavaScript文件、CSS文件或者HTML文件,您都能夠在Asp.Net Core中直接當(dāng)靜態(tài)文件使用。
- 在如果你想 讓index.html作為您的默認(rèn)文件,IIS一直有這種功能。
- 你可以給 IIS 一個(gè)默認(rèn)文件列表。如果有人訪問(wèn)根目錄,在這種情況下,如果 IIS 找到命名為 index.html的文件,它就會(huì)自動(dòng)將該文件返回給客戶端。
- 讓我們現(xiàn)在開始進(jìn)行少量更改。首先,我們需要?jiǎng)h除強(qiáng)制的錯(cuò)誤,然后添加另一塊的中間件,這就是 UseDefaultFiles。以下是配置方法的實(shí)現(xiàn)。
/ This method gets called by the runtime.
// Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app) {
app.UseIISPlatformHandler();
app.UseDeveloperExceptionPage();
app.UseRuntimeInfoPage();
app.UseDefaultFiles();
app.UseStaticFiles();
app.Run(async (context) => {
var msg = Configuration["message"];
await context.Response.WriteAsync(msg);
});
}
這段中間件將監(jiān)聽傳入的請(qǐng)求,如果請(qǐng)求是根目錄,就查看是否有匹配的默認(rèn)文件。
您可以覆蓋這個(gè)中間件的選項(xiàng)來(lái)告訴它如何匹配默認(rèn)文件,但index.html是默認(rèn)情況下的一個(gè)默認(rèn)的文件。
讓我們保存 Startup.cs 文件并將您的瀏覽器轉(zhuǎn)到 web 應(yīng)用程序的根目錄。

你現(xiàn)在可以看到index.html是默認(rèn)文件。你安裝中間件的順序是很重要的,因?yàn)槿绻銓seDefaultFiles放置在UseStaticFiles之后,你將可能不會(huì)得到相同的結(jié)果。
如果你想要使用UseDefaultFiles和UseStaticFiles中間件,你可以使用另一個(gè)中間件Microsoft.aspnet.staticfiles,它也是NuGet包,它是一個(gè)服務(wù)器中間件。這本質(zhì)上是以正確的順序包含了默認(rèn)文件和靜態(tài)文件。
// This method gets called by the runtime.
// Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app) {
app.UseIISPlatformHandler();
app.UseDeveloperExceptionPage();
app.UseRuntimeInfoPage();
app. UseFileServer();
app.Run(async (context) => {
var msg = Configuration["message"];
await context.Response.WriteAsync(msg);
});
}
讓我們?cè)僖淮伪4?Startup.cs 文件。一旦你刷新瀏覽器,你將看到相同的結(jié)果,如下面的屏幕快照所示。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- ASP.NET?Core中的靜態(tài)文件
- 淺談ASP.NET Core靜態(tài)文件處理源碼探究
- 1個(gè)文件如何輕松搞定Asp.net core 3.1動(dòng)態(tài)頁(yè)面轉(zhuǎn)靜態(tài)頁(yè)面
- ASP.NET Core 應(yīng)用程序中的靜態(tài)文件中間件的實(shí)現(xiàn)
- ASP.NET Core靜態(tài)文件的使用方法
- ASP.NET Core中預(yù)壓縮靜態(tài)文件的方法步驟
- 解析如何利用一個(gè)ASP.NET Core應(yīng)用來(lái)發(fā)布靜態(tài)文件
- ASP.NET Core中的靜態(tài)文件介紹
相關(guān)文章
ASP.NET實(shí)現(xiàn)個(gè)人信息注冊(cè)頁(yè)面并跳轉(zhuǎn)顯示
這篇文章主要介紹了ASP.NET實(shí)現(xiàn)個(gè)人信息注冊(cè)頁(yè)面并跳轉(zhuǎn)顯示的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12
ASP.NET CORE學(xué)習(xí)教程之自定義異常處理詳解
這篇文章主要給大家介紹了關(guān)于ASP.NET CORE學(xué)習(xí)教程之自定義異常處理的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01
運(yùn)用.NetCore實(shí)例講解RabbitMQ死信隊(duì)列,延時(shí)隊(duì)列
這篇文章主要運(yùn)用.NetCore實(shí)例講解RabbitMQ死信隊(duì)列,延時(shí)隊(duì)列,,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-09-09
Asp.net下拉樹的實(shí)現(xiàn)過(guò)程
這篇文章主要介紹了Asp.net下拉樹的實(shí)現(xiàn)過(guò)程,文章思路清晰,推薦給大家閱讀,需要的朋友可以參考下2015-08-08
.net實(shí)現(xiàn)微信公眾賬號(hào)接口開發(fā)實(shí)例代碼
這篇文章主要介紹了.net實(shí)現(xiàn)微信公眾賬號(hào)接口開發(fā)實(shí)例代碼,有需要的朋友可以參考一下2013-12-12
.NET?Core使用Eureka實(shí)現(xiàn)服務(wù)注冊(cè)
這篇文章介紹了.NET?Core使用Eureka實(shí)現(xiàn)服務(wù)注冊(cè)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07
.Net Core WebApi部署在Linux服務(wù)器上的方法
這篇文章主要介紹了.Net Core WebApi部署在Linux服務(wù)器上的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03

