訓練
學習路徑
了解使用 ASP.NET Core 建置 Web 應用程式的基礎。 此學習路徑會教導使用 ASP.NET Core 進行前端和後端開發所需的基本概念。
注意
這不是這篇文章的最新版本。 如需目前的版本,請參閱 本文的 .NET 9 版本。
警告
不再支援此版本的 ASP.NET Core。 如需詳細資訊,請參閱 .NET 和 .NET Core 支持原則。 如需目前的版本,請參閱 本文的 .NET 9 版本。
本文提供建置 ASP.NET Core 應用程式的基本概念概觀,包括相依性插入 (DI)、設定、中介軟體等等。
如需 Blazor 基本概念指引,這會新增或取代本文中的指導方針,請參閱 ASP.NET Core Blazor 基本概念。
使用 Web 範本建立的 ASP.NET Core 應用程式包含 Program.cs
檔案中的應用程式啟動程式碼。
Program.cs
檔案位於下列位置:
下列應用程式啟動程式代碼支援數種應用程式類型:
using WebAll.Components;
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorComponents()
.AddInteractiveServerComponents();
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseAuthorization();
app.MapGet("/hi", () => "Hello!");
app.MapDefaultControllerRoute();
app.MapRazorPages();
app.MapRazorComponents<App>()
.AddInteractiveServerRenderMode();
app.UseAntiforgery();
app.Run();
ASP.NET Core 功能內建的 相依注入 (DI),讓設定好的服務能在整個應用程式中使用。 在上述程式碼中,服務會新增至具有 WebApplicationBuilder.Services、builder.Services
的 DI 容器。 具現化 WebApplicationBuilder 時,會自動新增許多 架構提供的服務項目。
builder
是下列程式碼中的 WebApplicationBuilder
:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
在上述程式代碼中,CreateBuilder
將設定、記錄和 許多其他服務 至 DI 容器。 DI 架構會在運行時間提供要求服務的實例。
下列程式代碼會將自訂 DbContext 和 Blazor 元件新增至 DI 容器:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddDbContextFactory<BlazorWebAppMoviesContext>(options =>
options.UseSqlServer(builder.Configuration.GetConnectionString("MoviesContext")
?? throw new InvalidOperationException("Connection string not found.")));
builder.Services.AddQuickGridEntityFrameworkAdapter();
builder.Services.AddDatabaseDeveloperPageExceptionFilter();
// Add services to the container.
builder.Services.AddRazorComponents()
.AddInteractiveServerComponents();
var app = builder.Build();
在 Blazor Web App中,服務通常會在執行時從 DI 解析,方法是在 Razor 元件中使用 @inject
指令,如下列範例所示:
@page "/movies"
@rendermode InteractiveServer
@using Microsoft.EntityFrameworkCore
@using Microsoft.AspNetCore.Components.QuickGrid
@using BlazorWebAppMovies.Models
@using BlazorWebAppMovies.Data
@implements IAsyncDisposable
@inject IDbContextFactory<BlazorWebAppMovies.Data.BlazorWebAppMoviesContext> DbFactory
<PageTitle>Index</PageTitle>
<h1>Index</h1>
<div>
<input type="search" @bind="titleFilter" @bind:event="oninput" />
</div>
<p>
<a href="movies/create">Create New</a>
</p>
<QuickGrid Class="table" Items="FilteredMovies" Pagination="pagination">
<PropertyColumn Property="movie => movie.Title" Sortable="true" />
<PropertyColumn Property="movie => movie.ReleaseDate" Title="Release Date" />
<PropertyColumn Property="movie => movie.Genre" />
<PropertyColumn Property="movie => movie.Price" />
<PropertyColumn Property="movie => movie.Rating" />
<TemplateColumn Context="movie">
<a href="@($"movies/edit?id={movie.Id}")">Edit</a> |
<a href="@($"movies/details?id={movie.Id}")">Details</a> |
<a href="@($"movies/delete?id={movie.Id}")">Delete</a>
</TemplateColumn>
</QuickGrid>
<Paginator State="pagination" />
@code {
private BlazorWebAppMoviesContext context = default!;
private PaginationState pagination = new PaginationState { ItemsPerPage = 10 };
private string titleFilter = string.Empty;
private IQueryable<Movie> FilteredMovies =>
context.Movie.Where(m => m.Title!.Contains(titleFilter));
protected override void OnInitialized()
{
context = DbFactory.CreateDbContext();
}
public async ValueTask DisposeAsync() => await context.DisposeAsync();
}
在上述程式代碼中:
@inject
指示詞。OnInitialized
方法中解析,並指派給 context
變數。context
服務創建 FilteredMovie
清單。另一種從 DI 解析服務的方法是透過建構子注入。 下列 Razor Pages 程式代碼會使用建構函式插入解析資料庫內容和 DI 的記錄器:
public class IndexModel : PageModel
{
private readonly RazorPagesMovieContext _context;
private readonly ILogger<IndexModel> _logger;
public IndexModel(RazorPagesMovieContext context, ILogger<IndexModel> logger)
{
_context = context;
_logger = logger;
}
public IList<Movie> Movie { get;set; }
public async Task OnGetAsync()
{
_logger.LogInformation("IndexModel OnGetAsync.");
Movie = await _context.Movie.ToListAsync();
}
}
在上述程式代碼中,IndexModel
建構函式會採用類型為 RazorPagesMovieContext
的參數,其會在運行時間解析為 _context
變數。 內容物件可用來在 OnGetAsync
方法中建立電影清單。
如需詳細資訊,請參閱 ASP.NET Core Blazor 相依性注入 和 ASP.NET Core中的相依性注入。
要求處理管線由一系列中介軟體元件所組成。 每個元件會在 HttpContext
上執行操作,並叫用管線中下一個中介軟體或終止要求。
依照慣例,中介軟體元件會透過叫用 Use{Feature}
延伸模組方法來新增至管線。 下列程式代碼說明如何使用名為 Use{Feature}
的方法,將中間件新增至應用程式:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddDbContextFactory<BlazorWebAppMoviesContext>(options =>
options.UseSqlServer(builder.Configuration.GetConnectionString("MoviesContext")
?? throw new InvalidOperationException("Connection string not found.")));
builder.Services.AddQuickGridEntityFrameworkAdapter();
builder.Services.AddDatabaseDeveloperPageExceptionFilter();
// Add services to the container.
builder.Services.AddRazorComponents()
.AddInteractiveServerComponents();
var app = builder.Build();
using (var scope = app.Services.CreateScope())
{
var services = scope.ServiceProvider;
SeedData.Initialize(services);
}
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error", createScopeForErrors: true);
app.UseHsts();
app.UseMigrationsEndPoint();
}
app.UseHttpsRedirection();
app.UseAntiforgery();
app.MapStaticAssets();
app.MapRazorComponents<App>()
.AddInteractiveServerRenderMode();
app.Run();
如需詳細資訊,請參閱 ASP.NET Core 中介軟體。
在啟動時,ASP.NET Core 應用程式會建置一個「主機」。 主機會封裝所有應用程式的資源,例如:
有三個不同的主機能夠執行 ASP.NET Core 應用程式:
建議使用 ASP.NET Core WebApplication 和 WebApplicationBuilder 類型,並用於所有 ASP.NET Core 範本中。
WebApplication
的行為類似於 .NET 泛型主機,並公開許多相同的介面,但需要較少的回呼才能設定。 ASP.NET Core WebHost 僅適用於回溯相容性。
下列範例會具現化 WebApplication
,並將它指派給名為 app
的變數:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddDbContextFactory<BlazorWebAppMoviesContext>(options =>
options.UseSqlServer(builder.Configuration.GetConnectionString("MoviesContext")
?? throw new InvalidOperationException("Connection string not found.")));
builder.Services.AddQuickGridEntityFrameworkAdapter();
builder.Services.AddDatabaseDeveloperPageExceptionFilter();
// Add services to the container.
builder.Services.AddRazorComponents()
.AddInteractiveServerComponents();
var app = builder.Build();
WebApplicationBuilder.Build 方法會使用一組預設選項來設定主機,例如:
appsettings.json
。一般主機可讓其他類型的應用程式使用跨領域架構延伸模組,例如記錄、相依性插入 (DI)、組態和應用程式存留期管理。 如需詳細資訊,請參閱 ASP.NET Core 中的 .NET 泛型主機,以及在 ASP.NET Core 中使用託管服務的背景工作。
ASP.NET Core 應用程式使用 HTTP 伺服器實作來接聽 HTTP 要求。 伺服器會把向應用程式發出的要求作為一組要求功能,合併成一個 HttpContext。
ASP.NET Core 提供 Kestrel 跨平台伺服器實作。 在 ASP.NET Core 2.0 或更新版本中,Kestrel 可以做為直接向網際網路公開的公眾 Edge Server 執行。 Kestrel 通常會使用 Nginx 或 Apache 在反向 Proxy 設定中執行。
如需詳細資訊,請參閱在 ASP.NET Core 中實作網頁伺服器。
ASP.NET Core 提供組態架構,可從組態提供者的已排序集合中,以成對名稱和數值的形式取得設定。 您可以使用各種來源的內建組態提供者,例如 .json
檔案、.xml
檔案、環境變數及命令列引數。 撰寫自訂組態提供者以支援其他來源。
根據預設,ASP.NET Core 應用程式會設定為從 appsettings.json
、環境變數、命令列等進行讀取。 載入應用程式的組態時,來自環境變數的值會覆寫來自 appsettings.json
的值。
為了在開發環境中管理機密設定數據,例如密碼,.NET Core 提供 Secret Manager。 針對生產祕密,我們建議使用 Azure Key Vault。
如需詳細資訊,請參閱 ASP.NET Core 中的組態。
ASP.NET Core 中提供執行環境,例如 Development
、Staging
和 Production
。 透過設定 ASPNETCORE_ENVIRONMENT
環境變數來指定應用程式執行的環境。 ASP.NET Core 會在應用程式啟動時讀取環境變數,然後將值儲存在 IWebHostEnvironment
實作中。 您可在應用程式中透過相依性插入 (DI) 取得此實作。
下列範例會在未於 環境中執行時,設定例外處理常式和 Development
中介軟體:
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error", createScopeForErrors: true);
app.UseHsts();
app.UseMigrationsEndPoint();
}
如需詳細資訊,請參閱在 ASP.NET Core 中使用多個環境 (部分機器翻譯)。
ASP.NET Core 支援記錄 API,此 API 能與各種內建和第三方記錄提供者搭配使用。 可用的提供者包括:
若要建立記錄,ILogger<TCategoryName>請從相依性插入 (DI) 和通話記錄方法 (例如 LogInformation) 解析服務。 下列範例示範如何取得和使用 Blazor Web App中頁面 .razor
檔案中的記錄器。 當在 Program.cs
中呼叫 CreateBuilder 方法時,記錄器物件及其控制台提供者會自動儲存在 DI 容器中。
@page "/weather"
@attribute [StreamRendering]
@inject ILogger<Weather> Logger
<PageTitle>Weather</PageTitle>
<h1>Weather</h1>
<p>This component demonstrates showing data and logging.</p>
@if (forecasts == null)
{
<p><em>Loading...</em></p>
}
else
{
<table class="table">
<thead>
<tr>
<th>Date</th>
<th aria-label="Temperature in Celsius">Temp. (C)</th>
<th aria-label="Temperature in Fahrenheit">Temp. (F)</th>
<th>Summary</th>
</tr>
</thead>
<tbody>
@foreach (var forecast in forecasts)
{
<tr>
<td>@forecast.Date.ToShortDateString()</td>
<td>@forecast.TemperatureC</td>
<td>@forecast.TemperatureF</td>
<td>@forecast.Summary</td>
</tr>
}
</tbody>
</table>
}
@code {
private WeatherForecast[]? forecasts;
protected override async Task OnInitializedAsync()
{
// Simulate asynchronous loading to demonstrate streaming rendering
await Task.Delay(500);
Logger.LogInformation("This is an information log message.");
Logger.LogWarning("This is a warning log message.");
Logger.LogError("This is an error log message.");
var startDate = DateOnly.FromDateTime(DateTime.Now);
var summaries = new[] { "Freezing", "Bracing", "Chilly",
"Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching" };
forecasts = Enumerable.Range(1, 5).Select(index => new WeatherForecast
{
Date = startDate.AddDays(index),
TemperatureC = Random.Shared.Next(-20, 55),
Summary = summaries[Random.Shared.Next(summaries.Length)]
}).ToArray();
}
private class WeatherForecast
{
public DateOnly Date { get; set; }
public int TemperatureC { get; set; }
public string? Summary { get; set; }
public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);
}
}
如需詳細資料,請參閱 .NET Core 與 ASP.NET Core 中的記錄。
ASP.NET Core 中的路由是將連入要求對應至應用程式中特定端點的機制。 它可讓您定義對應至不同元件的 URL 模式,例如 Blazor 元件、Razor 頁面、MVC 控制器動作或中間件。
UseRouting(IApplicationBuilder) 方法會將路由中間件新增至要求管線。 此中間件會處理路由資訊,並判斷每個要求的適當端點。 除非您想要變更中間件處理的順序,否則您不需要明確呼叫 UseRouting
。
如需詳細資訊,請參閱 ASP.NET Core 和
ASP.NET Core 具有處理錯誤的內建功能,例如:
如需詳細資訊,請參閱處理 ASP.NET Core 中的錯誤。
IHttpClientFactory 的實作可用於建立 HttpClient 執行個體。 Factory:
HttpClient
執行個體。 例如,註冊並設定 Github 用戶端以存取 GitHub。 註冊並設定預設用戶端以供其他用途使用。HttpClient
存留期時,發生的常見 DNS 問題。如需詳細資訊,請參閱在 ASP.NET Core 中使用 IHttpClientFactory 發出 HTTP 要求。
內容根目錄是下列項目的基底路徑:
.cshtml
、.razor
).json
、.xml
).db
)在開發期間,內容根目錄預設為專案的根目錄。 此目錄也是應用程式內容檔案和 Web 根目錄的基底路徑。 指定不同的內容根目錄,方法是在建置主機時設定其路徑。 如需詳細資訊,請參閱內容根。
Web 根目錄是公用靜態資源檔的基底路徑,例如:
.css
).js
).png
、.jpg
)根據預設,靜態檔案只會處理來自 Web 根目錄及其子目錄的檔案。 Web 根路徑預設為 {content root}/wwwroot。 指定不同的 Web 根目錄,方法是在建置主機時設定其路徑。 如需詳細資訊,請參閱 Web 根目錄。
防止在 wwwroot 中使用專案檔中的>來發佈檔案。 下列範例會防止在 wwwroot/local 及其子目錄中發佈內容:
<ItemGroup>
<Content Update="wwwroot\local\**\*.*" CopyToPublishDirectory="Never" />
</ItemGroup>
在 Razor.cshtml
檔案中,~/
會指向 Web 根目錄。 開頭為 ~/
的路徑稱為虛擬路徑。
如需詳細資訊,請參閱 ASP.NET Core 中的靜態檔案。
本文提供建置 ASP.NET Core 應用程式的基本概念概觀,包括相依性插入 (DI)、設定、中介軟體等等。
使用 Web 範本建立的 ASP.NET Core 應用程式包含 Program.cs
檔案中的應用程式啟動程式碼。
Program.cs
檔案位於下列位置:
下列應用程式啟動程式碼支援:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseAuthorization();
app.MapGet("/hi", () => "Hello!");
app.MapDefaultControllerRoute();
app.MapRazorPages();
app.Run();
ASP.NET Core 包含相依性插入 (DI),可讓整個應用程式使用所設定服務。 在上述程式碼中,服務會新增至具有 WebApplicationBuilder.Services、builder.Services
的 DI 容器。 具現化 WebApplicationBuilder 時,會新增許多架構所提供的服務。
builder
是下列程式碼中的 WebApplicationBuilder
:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
在上述反白顯示的程式碼中,builder
已將組態、記錄和許多其他服務新增至 DI 容器。
下列程式碼會將 Razor Pages、具有檢視的 MVC 控制器,以及自訂的 DbContext 新增至 DI 容器:
using Microsoft.EntityFrameworkCore;
using RazorPagesMovie.Data;
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
builder.Services.AddDbContext<RazorPagesMovieContext>(options =>
options.UseSqlServer(builder.Configuration.GetConnectionString("RPMovieContext")));
var app = builder.Build();
通常會使用建構函式插入從 DI 解析服務。 DI 架構會在執行階段提供此服務的執行個體。
下列程式碼會使用建構函式插入,從 DI 解析資料庫內容和記錄器:
public class IndexModel : PageModel
{
private readonly RazorPagesMovieContext _context;
private readonly ILogger<IndexModel> _logger;
public IndexModel(RazorPagesMovieContext context, ILogger<IndexModel> logger)
{
_context = context;
_logger = logger;
}
public IList<Movie> Movie { get;set; }
public async Task OnGetAsync()
{
_logger.LogInformation("IndexModel OnGetAsync.");
Movie = await _context.Movie.ToListAsync();
}
}
要求處理管線由一系列中介軟體元件所組成。 每個元件會在 HttpContext
上執行操作,並叫用管線中下一個中介軟體或終止要求。
依照慣例,中介軟體元件會透過叫用 Use{Feature}
延伸模組方法來新增至管線。 下列程式碼中會將新增至應用程式的中介軟體反白顯示:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseAuthorization();
app.MapGet("/hi", () => "Hello!");
app.MapDefaultControllerRoute();
app.MapRazorPages();
app.Run();
如需詳細資訊,請參閱 ASP.NET Core 中介軟體。
在啟動時,ASP.NET Core 應用程式會建置一個「主機」。 主機會封裝所有應用程式的資源,例如:
有三個不同的主機能夠執行 ASP.NET Core 應用程式:
建議使用 ASP.NET Core WebApplication 和 WebApplicationBuilder 類型,並用於所有 ASP.NET Core 範本。
WebApplication
的運作方式與 .NET 泛型主機類似,並公開許多相同的介面,但需要較少的回呼進行設定。 ASP.NET Core WebHost 僅適用於回溯相容性。
下列範例會具現化 WebApplication
:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
WebApplicationBuilder.Build 方法會使用一組預設選項來設定主機,例如:
appsettings.json
。一般主機允許其他類型的應用程式,使用交叉剪輯架構延伸模組,例如記錄、相依性插入 (DI)、設定與應用程式存留期管理。 如需詳細資訊,請參閱 ASP.NET Core 中的 .NET 泛型主機,以及在 ASP.NET Core 中使用託管服務的背景工作。
ASP.NET Core 應用程式使用 HTTP 伺服器實作來接聽 HTTP 要求。 伺服器會把向應用程式發出的要求作為一組要求功能,合併成一個 HttpContext
。
ASP.NET Core 提供 Kestrel 跨平台伺服器實作。 在 ASP.NET Core 2.0 或更新版本中,Kestrel 可以做為直接向網際網路公開的公眾 Edge Server 執行。 Kestrel 通常會使用 Nginx 或 Apache 在反向 Proxy 設定中執行。
如需詳細資訊,請參閱在 ASP.NET Core 中實作網頁伺服器。
ASP.NET Core 提供組態架構,可從組態提供者的已排序集合中,以成對名稱和數值的形式取得設定。 您可以使用各種來源的內建組態提供者,例如 .json
檔案、.xml
檔案、環境變數及命令列引數。 撰寫自訂組態提供者以支援其他來源。
根據預設,ASP.NET Core 應用程式會設定為從 appsettings.json
、環境變數、命令列等進行讀取。 載入應用程式的組態時,來自環境變數的值會覆寫來自 appsettings.json
的值。
針對管理保密組態資料 (例如密碼),.NET Core 提供祕密管理員。 針對生產祕密,我們建議使用 Azure Key Vault。
如需詳細資訊,請參閱 ASP.NET Core 中的組態。
ASP.NET Core 中提供執行環境,例如 Development
、Staging
和 Production
。 透過設定 ASPNETCORE_ENVIRONMENT
環境變數來指定應用程式執行的環境。 ASP.NET Core 會在應用程式啟動時讀取環境變數,然後將值儲存在 IWebHostEnvironment
實作中。 您可在應用程式中透過相依性插入 (DI) 取得此實作。
下列範例會在未於 環境中執行時,設定例外處理常式和 Development
中介軟體:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseAuthorization();
app.MapGet("/hi", () => "Hello!");
app.MapDefaultControllerRoute();
app.MapRazorPages();
app.Run();
如需詳細資訊,請參閱在 ASP.NET Core 中使用多個環境 (部分機器翻譯)。
ASP.NET Core 支援記錄 API,此 API 能與各種內建和第三方記錄提供者搭配使用。 可用的提供者包括:
若要建立記錄,ILogger<TCategoryName>請從相依性插入 (DI) 和通話記錄方法 (例如 LogInformation) 解析服務。 例如:
public class IndexModel : PageModel
{
private readonly RazorPagesMovieContext _context;
private readonly ILogger<IndexModel> _logger;
public IndexModel(RazorPagesMovieContext context, ILogger<IndexModel> logger)
{
_context = context;
_logger = logger;
}
public IList<Movie> Movie { get;set; }
public async Task OnGetAsync()
{
_logger.LogInformation("IndexModel OnGetAsync.");
Movie = await _context.Movie.ToListAsync();
}
}
如需詳細資料,請參閱 .NET Core 與 ASP.NET Core 中的記錄。
「路由」是一種對應到處理常式的 URL 模式。 處理常式通常是 Razor 頁面、MVC 控制器中的動作方法,或是中介軟體。 ASP.NET Core 路由可讓您控制您應用程式使用的 URL。
ASP.NET Core Web 應用程式範本所產生的下列程式碼會呼叫 UseRouting:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddRazorPages();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseAuthorization();
app.MapRazorPages();
app.Run();
如需詳細資訊,請參閱 ASP.NET Core 中的路線規劃。
ASP.NET Core 具有處理錯誤的內建功能,例如:
如需詳細資訊,請參閱處理 ASP.NET Core 中的錯誤。
IHttpClientFactory
的實作可用於建立 HttpClient
執行個體。 Factory:
HttpClient
執行個體。 例如,註冊並設定 Github 用戶端以存取 GitHub。 註冊並設定預設用戶端以供其他用途使用。HttpClientHandler
執行個體的共用和存留期,以避免在手動管理 HttpClient
存留期時,發生的常見 DNS 問題。如需詳細資訊,請參閱在 ASP.NET Core 中使用 IHttpClientFactory 發出 HTTP 要求。
內容根目錄是下列項目的基底路徑:
.cshtml
、.razor
).json
、.xml
).db
)在開發期間,內容根目錄預設為專案的根目錄。 此目錄也是應用程式內容檔案和 Web 根目錄的基底路徑。 指定不同的內容根目錄,方法是在建置主機時設定其路徑。 如需詳細資訊,請參閱內容根。
Web 根目錄是公用靜態資源檔的基底路徑,例如:
.css
).js
).png
、.jpg
)根據預設,靜態檔案只會處理來自 Web 根目錄及其子目錄的檔案。 Web 根路徑預設為 {content root}/wwwroot。 指定不同的 Web 根目錄,方法是在建置主機時設定其路徑。 如需詳細資訊,請參閱 Web 根目錄。
防止在 wwwroot 中使用專案檔中的>來發佈檔案。 下列範例會防止在 wwwroot/local 及其子目錄中發佈內容:
<ItemGroup>
<Content Update="wwwroot\local\**\*.*" CopyToPublishDirectory="Never" />
</ItemGroup>
在 Razor.cshtml
檔案中,~/
會指向 Web 根目錄。 開頭為 ~/
的路徑稱為虛擬路徑。
如需詳細資訊,請參閱 ASP.NET Core 中的靜態檔案。
本文提供建置 ASP.NET Core 應用程式的基本概念概觀,包括相依性插入 (DI)、設定、中介軟體等等。
Startup
類別是:
以下是 Startup
類別範例:
public class Startup
{
public void ConfigureServices(IServiceCollection services)
{
services.AddDbContext<RazorPagesMovieContext>(options =>
options.UseSqlServer(Configuration.GetConnectionString("RazorPagesMovieContext")));
services.AddControllersWithViews();
services.AddRazorPages();
}
public void Configure(IApplicationBuilder app)
{
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseEndpoints(endpoints =>
{
endpoints.MapDefaultControllerRoute();
endpoints.MapRazorPages();
});
}
}
如需詳細資訊,請參閱 ASP.NET Core 中的應用程式啟動。
ASP.NET Core 包含內建的相依性插入 (DI) 架構,可讓整個應用程式使用所設定服務。 例如,記錄元件即為一項服務。
設定 (或「註冊」) 服務的程式碼會新增至 Startup.ConfigureServices
方法。 例如:
public void ConfigureServices(IServiceCollection services)
{
services.AddDbContext<RazorPagesMovieContext>(options =>
options.UseSqlServer(Configuration.GetConnectionString("RazorPagesMovieContext")));
services.AddControllersWithViews();
services.AddRazorPages();
}
通常會使用建構函式插入從 DI 解析服務。 類別會使用建構函式插入來宣告必要類型或介面的建構函式參數。 DI 架構會在執行階段提供此服務的執行個體。
下列範例會使用建構函式插入從 DI 解析 RazorPagesMovieContext
:
public class IndexModel : PageModel
{
private readonly RazorPagesMovieContext _context;
public IndexModel(RazorPagesMovieContext context)
{
_context = context;
}
// ...
public async Task OnGetAsync()
{
Movies = await _context.Movies.ToListAsync();
}
}
如果內建的控制反轉 (IoC) 容器不符合應用程式的所有需求,則可以改用協力廠商 IoC 容器。
如需詳細資訊,請參閱在 ASP.NET Core 中插入相依性。
要求處理管線由一系列中介軟體元件所組成。 每個元件會在 HttpContext
上執行操作,並叫用管線中下一個中介軟體或終止要求。
依照慣例,中介軟體元件會透過叫用 Use...
方法中的 Startup.Configure
延伸模組方法來新增至管線。 例如,若要啟用靜態檔案轉譯,請呼叫 UseStaticFiles
。
下列範例會設定要求處理管線:
public void Configure(IApplicationBuilder app)
{
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseEndpoints(endpoints =>
{
endpoints.MapDefaultControllerRoute();
endpoints.MapRazorPages();
});
}
ASP.NET Core 內含一組豐富的內建中介軟體。 您也可以撰寫自訂中介軟體元件。
如需詳細資訊,請參閱 ASP.NET Core 中介軟體。
在啟動時,ASP.NET Core 應用程式會建置一個「主機」。 主機會封裝所有應用程式的資源,例如:
有兩個不同的主機:
建議使用 .NET 泛型主機。 ASP.NET Core Web 主機僅適用於回溯相容性。
下列範例會建立 .NET 泛型主機:
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<Startup>();
});
}
CreateDefaultBuilder
和 ConfigureWebHostDefaults
方法會使用一組預設選項來設定主機,例如:
appsettings.json
、appsettings.{Environment}.json
、環境變數、命令列引數及其他來源載入組態。如需詳細資訊,請參閱 ASP.NET 中的 .NET 泛型主機。
一般主機允許其他類型的應用程式,使用交叉剪輯架構延伸模組,例如記錄、相依性插入 (DI)、設定與應用程式存留期管理。 如需詳細資訊,請參閱 ASP.NET Core 中的 .NET 泛型主機,以及在 ASP.NET Core 中使用託管服務的背景工作。
ASP.NET Core 應用程式使用 HTTP 伺服器實作來接聽 HTTP 要求。 伺服器會把向應用程式發出的要求作為一組要求功能,合併成一個 HttpContext
。
ASP.NET Core 提供 Kestrel 跨平台伺服器實作。 在 ASP.NET Core 2.0 或更新版本中,Kestrel 可以做為直接向網際網路公開的公眾 Edge Server 執行。 Kestrel 通常會使用 Nginx 或 Apache 在反向 Proxy 設定中執行。
如需詳細資訊,請參閱在 ASP.NET Core 中實作網頁伺服器。
ASP.NET Core 提供組態架構,可從組態提供者的已排序集合中,以成對名稱和數值的形式取得設定。 您可以使用各種來源的內建組態提供者,例如 .json
檔案、.xml
檔案、環境變數及命令列引數。 撰寫自訂組態提供者以支援其他來源。
根據預設,ASP.NET Core 應用程式會設定為從 appsettings.json
、環境變數、命令列等進行讀取。 載入應用程式的組態時,來自環境變數的值會覆寫來自 appsettings.json
的值。
讀取相關設定值的慣用方式是使用選項模式 (部分機器翻譯)。 如需詳細資訊,請參閱使用選項模式繫結階層式設定資料。
針對管理保密組態資料 (例如密碼),.NET Core 提供祕密管理員。 針對生產祕密,我們建議使用 Azure Key Vault。
如需詳細資訊,請參閱 ASP.NET Core 中的組態。
執行環境 (例如 Development
、Staging
和 Production
) 是 ASP.NET Core 中的第一級概念。 透過設定 ASPNETCORE_ENVIRONMENT
環境變數來指定應用程式執行的環境。 ASP.NET Core 會在應用程式啟動時讀取環境變數,然後將值儲存在 IWebHostEnvironment
實作中。 您可在應用程式中透過相依性插入 (DI) 取得此實作。
下列範例會將應用程式設定為在 Development
環境中執行時,提供詳細的錯誤資訊:
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseEndpoints(endpoints =>
{
endpoints.MapDefaultControllerRoute();
endpoints.MapRazorPages();
});
}
如需詳細資訊,請參閱在 ASP.NET Core 中使用多個環境 (部分機器翻譯)。
ASP.NET Core 支援記錄 API,此 API 能與各種內建和第三方記錄提供者搭配使用。 可用的提供者包括:
若要建立記錄,ILogger<TCategoryName>請從相依性插入 (DI) 和通話記錄方法 (例如 LogInformation) 解析服務。 例如:
public class TodoController : ControllerBase
{
private readonly ILogger _logger;
public TodoController(ILogger<TodoController> logger)
{
_logger = logger;
}
[HttpGet("{id}", Name = "GetTodo")]
public ActionResult<TodoItem> GetById(string id)
{
_logger.LogInformation(LoggingEvents.GetItem, "Getting item {Id}", id);
// Item lookup code removed.
if (item == null)
{
_logger.LogWarning(LoggingEvents.GetItemNotFound, "GetById({Id}) NOT FOUND", id);
return NotFound();
}
return item;
}
}
記錄方法 (例如 LogInformation
) 支援任何數目的欄位。 這些欄位通常用來建構訊息 string
,但有些記錄提供者會將這些欄位傳送至資料存放區做為個別欄位。 這項功能可讓記錄提供者實作 semantic logging (語意記錄),又稱為 structured logging (結構化記錄)。
如需詳細資料,請參閱 .NET Core 與 ASP.NET Core 中的記錄。
「路由」是一種對應到處理常式的 URL 模式。 處理常式通常是 Razor 頁面、MVC 控制器中的動作方法,或是中介軟體。 ASP.NET Core 路由可讓您控制您應用程式使用的 URL。
如需詳細資訊,請參閱 ASP.NET Core 中的路線規劃。
ASP.NET Core 具有處理錯誤的內建功能,例如:
如需詳細資訊,請參閱處理 ASP.NET Core 中的錯誤。
IHttpClientFactory
的實作可用於建立 HttpClient
執行個體。 Factory:
HttpClient
執行個體。 例如,註冊並設定 Github 用戶端以存取 GitHub。 註冊並設定預設用戶端以供其他用途使用。HttpClientHandler
執行個體的共用和存留期,以避免在手動管理 HttpClient
存留期時,發生的常見 DNS 問題。如需詳細資訊,請參閱在 ASP.NET Core 中使用 IHttpClientFactory 發出 HTTP 要求。
內容根目錄是下列項目的基底路徑:
.cshtml
、.razor
).json
、.xml
).db
)在開發期間,內容根目錄預設為專案的根目錄。 此目錄也是應用程式內容檔案和 Web 根目錄的基底路徑。 指定不同的內容根目錄,方法是在建置主機時設定其路徑。 如需詳細資訊,請參閱內容根。
Web 根目錄是公用靜態資源檔的基底路徑,例如:
.css
).js
).png
、.jpg
)根據預設,靜態檔案只會處理來自 Web 根目錄及其子目錄的檔案。 Web 根路徑預設為 {content root}/wwwroot。 指定不同的 Web 根目錄,方法是在建置主機時設定其路徑。 如需詳細資訊,請參閱 Web 根目錄。
防止在 wwwroot 中使用專案檔中的>來發佈檔案。 下列範例會防止在 wwwroot/local 及其子目錄中發佈內容:
<ItemGroup>
<Content Update="wwwroot\local\**\*.*" CopyToPublishDirectory="Never" />
</ItemGroup>
在 Razor.cshtml
檔案中,tilde-slash (~/
) 會指向 Web 根目錄。 開頭為 ~/
的路徑稱為虛擬路徑。
如需詳細資訊,請參閱 ASP.NET Core 中的靜態檔案。
本文提供建置 ASP.NET Core 應用程式的基本概念概觀,包括相依性插入 (DI)、設定、中介軟體等等。
如需 Blazor 基礎知識指引 (其會新增或取代此節點中的指引),請參閱 ASP.NET Core Blazor 基本概念。
使用 Web 範本建立的 ASP.NET Core 應用程式包含 Program.cs
檔案中的應用程式啟動程式碼。
Program.cs
檔案位於下列位置:
下列應用程式啟動程式碼支援:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseAuthorization();
app.MapGet("/hi", () => "Hello!");
app.MapDefaultControllerRoute();
app.MapRazorPages();
app.Run();
ASP.NET Core 包含相依性插入 (DI),可讓整個應用程式使用所設定服務。 在上述程式碼中,服務會新增至具有 WebApplicationBuilder.Services、builder.Services
的 DI 容器。 具現化 WebApplicationBuilder 時,會新增許多架構所提供的服務。
builder
是下列程式碼中的 WebApplicationBuilder
:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
在上述反白顯示的程式碼中,builder
已將組態、記錄和許多其他服務新增至 DI 容器。
下列程式碼會將 Razor Pages、具有檢視的 MVC 控制器,以及自訂的 DbContext 新增至 DI 容器:
using Microsoft.EntityFrameworkCore;
using RazorPagesMovie.Data;
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
builder.Services.AddDbContext<RazorPagesMovieContext>(options =>
options.UseSqlServer(builder.Configuration.GetConnectionString("RPMovieContext")));
var app = builder.Build();
通常會使用建構函式插入從 DI 解析服務。 DI 架構會在執行階段提供此服務的執行個體。
下列程式碼會使用建構函式插入,從 DI 解析資料庫內容和記錄器:
public class IndexModel : PageModel
{
private readonly RazorPagesMovieContext _context;
private readonly ILogger<IndexModel> _logger;
public IndexModel(RazorPagesMovieContext context, ILogger<IndexModel> logger)
{
_context = context;
_logger = logger;
}
public IList<Movie> Movie { get;set; }
public async Task OnGetAsync()
{
_logger.LogInformation("IndexModel OnGetAsync.");
Movie = await _context.Movie.ToListAsync();
}
}
要求處理管線由一系列中介軟體元件所組成。 每個元件會在 HttpContext
上執行操作,並叫用管線中下一個中介軟體或終止要求。
依照慣例,中介軟體元件會透過叫用 Use{Feature}
延伸模組方法來新增至管線。 下列程式碼中會將新增至應用程式的中介軟體反白顯示:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseAuthorization();
app.MapGet("/hi", () => "Hello!");
app.MapDefaultControllerRoute();
app.MapRazorPages();
app.Run();
如需詳細資訊,請參閱 ASP.NET Core 中介軟體。
在啟動時,ASP.NET Core 應用程式會建置一個「主機」。 主機會封裝所有應用程式的資源,例如:
有三個不同的主機能夠執行 ASP.NET Core 應用程式:
建議使用 ASP.NET Core WebApplication 和 WebApplicationBuilder 類型,並用於所有 ASP.NET Core 範本。
WebApplication
的運作方式與 .NET 泛型主機類似,並公開許多相同的介面,但需要較少的回呼進行設定。 ASP.NET Core WebHost 僅適用於回溯相容性。
下列範例會具現化 WebApplication
:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
WebApplicationBuilder.Build 方法會使用一組預設選項來設定主機,例如:
appsettings.json
。一般主機允許其他類型的應用程式,使用交叉剪輯架構延伸模組,例如記錄、相依性插入 (DI)、設定與應用程式存留期管理。 如需詳細資訊,請參閱 ASP.NET Core 中的 .NET 泛型主機,以及在 ASP.NET Core 中使用託管服務的背景工作。
ASP.NET Core 應用程式使用 HTTP 伺服器實作來接聽 HTTP 要求。 伺服器會把向應用程式發出的要求作為一組要求功能,合併成一個 HttpContext
。
ASP.NET Core 提供 Kestrel 跨平台伺服器實作。 在 ASP.NET Core 2.0 或更新版本中,Kestrel 可以做為直接向網際網路公開的公眾 Edge Server 執行。 Kestrel 通常會使用 Nginx 或 Apache 在反向 Proxy 設定中執行。
如需詳細資訊,請參閱在 ASP.NET Core 中實作網頁伺服器。
ASP.NET Core 提供組態架構,可從組態提供者的已排序集合中,以成對名稱和數值的形式取得設定。 您可以使用各種來源的內建組態提供者,例如 .json
檔案、.xml
檔案、環境變數及命令列引數。 撰寫自訂組態提供者以支援其他來源。
根據預設,ASP.NET Core 應用程式會設定為從 appsettings.json
、環境變數、命令列等進行讀取。 載入應用程式的組態時,來自環境變數的值會覆寫來自 appsettings.json
的值。
針對管理保密組態資料 (例如密碼),.NET Core 提供祕密管理員。 針對生產祕密,我們建議使用 Azure Key Vault。
如需詳細資訊,請參閱 ASP.NET Core 中的組態。
ASP.NET Core 中提供執行環境,例如 Development
、Staging
和 Production
。 透過設定 ASPNETCORE_ENVIRONMENT
環境變數來指定應用程式執行的環境。 ASP.NET Core 會在應用程式啟動時讀取環境變數,然後將值儲存在 IWebHostEnvironment
實作中。 您可在應用程式中透過相依性插入 (DI) 取得此實作。
下列範例會在未於 環境中執行時,設定例外處理常式和 Development
中介軟體:
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddRazorPages();
builder.Services.AddControllersWithViews();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseAuthorization();
app.MapGet("/hi", () => "Hello!");
app.MapDefaultControllerRoute();
app.MapRazorPages();
app.Run();
如需詳細資訊,請參閱在 ASP.NET Core 中使用多個環境 (部分機器翻譯)。
ASP.NET Core 支援記錄 API,此 API 能與各種內建和第三方記錄提供者搭配使用。 可用的提供者包括:
若要建立記錄,ILogger<TCategoryName>請從相依性插入 (DI) 和通話記錄方法 (例如 LogInformation) 解析服務。 例如:
public class IndexModel : PageModel
{
private readonly RazorPagesMovieContext _context;
private readonly ILogger<IndexModel> _logger;
public IndexModel(RazorPagesMovieContext context, ILogger<IndexModel> logger)
{
_context = context;
_logger = logger;
}
public IList<Movie> Movie { get;set; }
public async Task OnGetAsync()
{
_logger.LogInformation("IndexModel OnGetAsync.");
Movie = await _context.Movie.ToListAsync();
}
}
如需詳細資料,請參閱 .NET Core 與 ASP.NET Core 中的記錄。
「路由」是一種對應到處理常式的 URL 模式。 處理常式通常是 Razor 頁面、MVC 控制器中的動作方法,或是中介軟體。 ASP.NET Core 路由可讓您控制您應用程式使用的 URL。
ASP.NET Core Web 應用程式範本所產生的下列程式碼會呼叫 UseRouting:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddRazorPages();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Error");
app.UseHsts();
}
app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseAuthorization();
app.MapRazorPages();
app.Run();
如需詳細資訊,請參閱 ASP.NET Core 中的路線規劃。
ASP.NET Core 具有處理錯誤的內建功能,例如:
如需詳細資訊,請參閱處理 ASP.NET Core 中的錯誤。
IHttpClientFactory
的實作可用於建立 HttpClient
執行個體。 Factory:
HttpClient
執行個體。 例如,註冊並設定 Github 用戶端以存取 GitHub。 註冊並設定預設用戶端以供其他用途使用。HttpClientHandler
執行個體的共用和存留期,以避免在手動管理 HttpClient
存留期時,發生的常見 DNS 問題。如需詳細資訊,請參閱在 ASP.NET Core 中使用 IHttpClientFactory 發出 HTTP 要求。
內容根目錄是下列項目的基底路徑:
.cshtml
、.razor
).json
、.xml
).db
)在開發期間,內容根目錄預設為專案的根目錄。 此目錄也是應用程式內容檔案和 Web 根目錄的基底路徑。 指定不同的內容根目錄,方法是在建置主機時設定其路徑。 如需詳細資訊,請參閱內容根。
Web 根目錄是公用靜態資源檔的基底路徑,例如:
.css
).js
).png
、.jpg
)根據預設,靜態檔案只會處理來自 Web 根目錄及其子目錄的檔案。 Web 根路徑預設為 {content root}/wwwroot。 指定不同的 Web 根目錄,方法是在建置主機時設定其路徑。 如需詳細資訊,請參閱 Web 根目錄。
防止在 wwwroot 中使用專案檔中的>來發佈檔案。 下列範例會防止在 wwwroot/local 及其子目錄中發佈內容:
<ItemGroup>
<Content Update="wwwroot\local\**\*.*" CopyToPublishDirectory="Never" />
</ItemGroup>
在 Razor.cshtml
檔案中,~/
會指向 Web 根目錄。 開頭為 ~/
的路徑稱為虛擬路徑。
如需詳細資訊,請參閱 ASP.NET Core 中的靜態檔案。
訓練
學習路徑
了解使用 ASP.NET Core 建置 Web 應用程式的基礎。 此學習路徑會教導使用 ASP.NET Core 進行前端和後端開發所需的基本概念。