ASP.NET Core 概觀
由 Daniel Roth、Rick Anderson 和 Shaun Luttin 提供
注意
這不是這篇文章的最新版本。 如需目前版本,請參閱本文的 .NET 8 版本。
警告
不再支援此版本的 ASP.NET Core。 如需詳細資訊,請參閱 .NET 和 .NET Core 支援原則。 如需目前版本,請參閱本文的 .NET 8 版本。
ASP.NET Core 是一種跨平台且高效能的開放原始碼架構,用於建置新式、啟用雲端且連線網際網路的應用程式。
利用 ASP.NET Core,您可以:
為什麼要選擇 ASP.NET Core?
數百萬的開發人員使用或已使用 ASP.NET 4.x 來建立 Web 應用程式。 ASP.NET Core 是 ASP.NET 4.x 的重新設計,包括可產生更為精簡且更加模組化架構的架構變更。
ASP.NET Core 提供下列優點:
- 用於建置 Web UI 和 Web API 的統一劇本。
- 可測試性架構。
- Razor Pages 更容易撰寫以頁面為焦點的案例程式碼,也更具生產力。
- Blazor 可讓您在瀏覽器中使用 C# 與 JavaScript。 共用伺服器端與用戶端應用程式邏輯都是以 .NET 撰寫。
- 能夠在 Windows、macOS 和 Linux 上開發並執行。
- 開放原始碼和社群導向。
- 整合的用戶端架構和開發工作流程。
- 支援使用 gRPC 裝載遠端程序呼叫 (RPC) 服務。
- 雲端就緒、以環境為基礎的組態系統。
- 內建的相依性插入。
- 輕量型、高效能且模組化的 HTTP 要求管線。
- 能夠裝載於下列項目:
- 並存版本。
- 可簡化現代網頁程式開發的工具。
使用 ASP.NET Core MVC 建置 Web API 和 Web UI
ASP.NET Core MVC 提供了建置 Web API 和 Web 應用程式的功能:
- 模型檢視控制器 (MVC) 模式有助於讓您的 Web API 和 Web 應用程式可測試。
- Razor Pages 是以頁面為基礎的程式設計模型,可讓建置 Web UI 更輕鬆與更具生產力。
- Razor 標記 提供適用於 Razor Pages 和 MVC 檢視的高效率語法。
- 標記協助程式可啟用伺服器端程式碼,以參與建立和轉譯 Razor 檔案中的 HTML 元素。
- 多個資料格式和內容交涉的內建支援可讓您的 Web API 連線到各種用戶端,包括瀏覽器和行動裝置。
- 模型繫結會自動將 HTTP 要求中的資料對應至動作方法參數。
- 模型驗證會自動執行用戶端和伺服器端驗證。
用戶端開發
ASP.NET Core 包括用於建置豐富的互動式 Web UI 的 Blazor,同時也可與其他熱門的前端 JavaScript 架構整合,例如 Angular、React、Vue 及 Bootstrap。 如需詳細資訊,請參閱 ASP.NET Core Blazor 以及<用戶端開發>底下的相關主題。
ASP.NET Core 目標架構
ASP.NET Core 3.x 或更新版本只能以 .NET 為目標。
以 .NET 為目標有幾個優點,而這些優點會隨著每個版本的發行而增加。 .NET 相較於 .NET Framework 的一些優點包括:
- 跨平台。 在 Windows、macOS 和 Linux 上執行。
- 提升效能
- 並存版本設定
- 新的 API
- 開放原始碼
建議學習路徑
建議使用下列一系列的教學課程,來取得開發 ASP.NET Core 應用程式的簡介:
遵循您想要開發或維護之應用程式類型的教學課程。
應用程式類型 案例 教學課程 Web 應用程式 新的伺服器端 Web UI 開發 開始使用 Razor Pages Web 應用程式 維護 MVC 應用程式 開始使用 MVC Web 應用程式 用戶端 Web UI 開發 開始使用 Blazor Web API RESTful HTTP 服務 建立 Web API† 遠端程序呼叫應用程式 使用通訊協定緩衝區的合約優先服務 開始使用 gRPC 服務 即時應用程式 伺服器與已連線用戶端之間的雙向通訊 開始使用 SignalR 遵循顯示如何進行基本資料存取的教學課程。
案例 教學課程 新的開發 搭配 Entity Framework Core 的 Razor Pages 維護 MVC 應用程式 搭配 Entity Framework Core 的 MVC 閱讀適用於所有應用程式類型的 ASP.NET Core 基礎概念。
瀏覽其他感興趣主題的目錄。
†另外還有互動式 Web API 教學課程。 不需要本機安裝開發工具。 程式碼會在瀏覽器內於 Azure Cloud Shell 中執行,而且會使用 curl 來進行測試。
從 .NET Framework 移轉
如需將 ASP.NET 4.x 應用程式移轉至 ASP.NET Core 的參考指南,請參閱從 ASP.NET 更新為 ASP.NET Core。
ASP.NET Core 是一種跨平台且高效能的開放原始碼架構,用於建置新式、啟用雲端且連線網際網路的應用程式。 利用 ASP.NET Core,您可以:
- 建置 Web 應用程式和服務、物聯網 (IoT) 應用程式,以及行動後端。
- 在 Windows、macOS 和 Linux 上使用您最愛的開發工具。
- 部署到雲端或在內部部署。
- 在 .NET Core 或 .NET Framework 上執行。
為什麼要選擇 ASP.NET Core?
數百萬的開發人員使用或已使用 ASP.NET 4.x 來建立 Web 應用程式。 ASP.NET Core 是 ASP.NET 4.x 的重新設計,其架構變更可產生更為精簡且更加模組化的架構。
ASP.NET Core 提供下列優點:
- 用於建置 Web UI 和 Web API 的統一劇本。
- 可測試性架構。
- Razor Pages 更容易撰寫以頁面為焦點的案例程式碼,也更具生產力。
- Blazor 可讓您在瀏覽器中使用 C# 與 JavaScript。 共用伺服器端與用戶端應用程式邏輯都是以 .NET 撰寫。
- 能夠在 Windows、macOS 和 Linux 上開發並執行。
- 開放原始碼和社群導向。
- 整合的用戶端架構和開發工作流程。
- 支援使用 gRPC 裝載遠端程序呼叫 (RPC) 服務。
- 雲端就緒、以環境為基礎的組態系統。
- 內建的相依性插入。
- 輕量型、高效能且模組化的 HTTP 要求管線。
- 能夠裝載於下列項目:
- 並存版本。
- 可簡化現代網頁程式開發的工具。
使用 ASP.NET Core MVC 建置 Web API 和 Web UI
ASP.NET Core MVC 提供了建置 Web API 和 Web 應用程式的功能:
- 模型檢視控制器 (MVC) 模式有助於讓您的 Web API 和 Web 應用程式可測試。
- Razor Pages 是以頁面為基礎的程式設計模型,可讓建置 Web UI 更輕鬆與更具生產力。
- Razor 標記 提供適用於 Razor Pages 和 MVC 檢視的高效率語法。
- 標記協助程式可啟用伺服器端程式碼,以參與建立和轉譯 Razor 檔案中的 HTML 元素。
- 多個資料格式和內容交涉的內建支援可讓您的 Web API 連線到各種用戶端,包括瀏覽器和行動裝置。
- 模型繫結會自動將 HTTP 要求中的資料對應至動作方法參數。
- 模型驗證會自動執行用戶端和伺服器端驗證。
用戶端開發
ASP.NET Core 可無縫地與熱門的用戶端架構和程式庫整合,包括 Blazor、Angular、React、Vue 與 Bootstrap。 如需詳細資訊,請參閱 ASP.NET Core Blazor 以及<用戶端開發>底下的相關主題。
將目標指向 .NET Framework 的 ASP.NET Core
ASP.NET Core 2.x 的目標可以是 NET Core 或 .NET Framework。 以 .NET Framework 為目標的 ASP.NET Core 應用程式無法跨平台,只能在 Windows 上執行。 ASP.NET Core 2.x 通常會包含 .NET Standard 程式庫。 使用 .NET Standard 2.0 撰寫的程式庫可在任何實作 .NET Standard 2.0 的 .NET 平台上執行。
實作 .NET Standard 2.0 的 .NET Framework 版本支援 ASP.NET Core 2.x:
- 建議使用 .NET Framework 最新版本。
- .NET Framework 4.6.1 或更新版本。
ASP.NET Core 3.0 或更新版本只能在 .NET Core 上執行。 如需此變更的詳細資料,請參閱A first look at changes coming in ASP.NET Core 3.0 (搶先看 ASP.NET Core 3.0 的變更)。
將目標指向 .NET Core 有多個好處,而這些好處也隨著版本更新越來越多。 NET Core 較 .NET Framework 多的好處包含:
- 跨平台。 可在 macOS、Linux 及 Windows 上執行。
- 提升效能
- 並存版本設定
- 新的 API
- 開放原始碼
為了協助縮小從 .NET Framework 到 .NET Core 的 API 差距,Windows 相容性套件已在 .NET Core 中提供數千個僅供 Windows 使用的 API。 這些 API 並不適用於 .NET Core 1.x。
建議學習路徑
我們建議遵循一系列的教學課程和文章,取得開發 ASP.NET Core 應用程式的簡介:
遵循您想要開發或維護之應用程式類型的教學課程。
應用程式類型 案例 教學課程 Web 應用程式 針對全新開發 開始使用 Razor Pages Web 應用程式 針對維護 MVC 應用程式 開始使用 MVC Web API 建立 Web API† 即時應用程式 開始使用 SignalR 遵循顯示如何進行基本資料存取的教學課程。
案例 教學課程 針對全新開發 搭配 Entity Framework Core 的 Razor Pages 針對維護 MVC 應用程式 搭配 Entity Framework Core 的 MVC 閱讀適用於所有應用程式類型的 ASP.NET Core 基礎概念。
瀏覽其他您感興趣主題的目錄。
†另外還有您可以在瀏覽器中完整遵循的 Web API 教學課程,而且不需要進行本機 IDE 安裝。 程式碼會在 Azure Cloud Shell 中執行,且會使用 curl 來進行測試。
從 .NET Framework 移轉
如需將 ASP.NET 應用程式移轉至 ASP.NET Core 的參考指南,請參閱從 ASP.NET 更新為 ASP.NET Core。
如何下載範例
許多文章及教學課程都有包含範例程式碼的連結。
- 下載 ASP.NET 存放庫 ZIP 檔案。
- 將
AspNetCore.Docs-main.zip
檔案解壓縮。 - 若要存取已解壓縮存放庫中的文章範例應用程式,請使用文章範例連結中的 URL 來協助您導覽至範例的資料夾。 通常,文章的範例連結會出現在文章頂端,其中包含連結文字檢視或下載範例程式碼。
範例程式碼中的前置處理器指示詞
為了示範多種案例,範例應用程式使用 #define
和 #if-#else/#elif-#endif
前置處理器指示詞,來選擇性地編譯和執行範例程式碼的不同區段。 針對利用此方式的範例,請設定 C# 檔案頂端的 #define
指示詞,以定義您想要執行之案例的相關聯符號。 部分範例會要求在多個檔案的頂端設定符號,以執行案例。
例如下列 #define
符號清單指出其提供四個情節 (每個符號一個情節)。 目前的範例設定會執行 TemplateCode
情節:
#define TemplateCode // or LogFromMain or ExpandDefault or FilterInCode
若要變更此範例,以執行 ExpandDefault
情節,請定義 ExpandDefault
符號,並將剩餘的符號設為註解:
#define ExpandDefault // TemplateCode or LogFromMain or FilterInCode
如需如何使用 C# 前置處理器指示詞,以選擇編譯不同之程式碼區段的詳細資訊,請參閱 #define (C# 參考) 及 #if (C# 參考)。
中斷性變更和安全性諮詢
公告存放庫上會報告中斷性變更和安全性諮詢。 選取 [標籤] 篩選,以將公告限制為特定版本。
下一步
如需詳細資訊,請參閱以下資源:
- 開始使用 ASP.NET Core
- 使用 Visual Studio 將 ASP.NET Core 應用程式發行到 Azure
- ASP.NET Core 基本概念
- 每週的 ASP.NET 社群之聲 \(英文\) 涵蓋了小組的進度和計劃, 並提供新的部落格和協力廠商軟體。