共用方式為


ASP.NET Core 概觀

Daniel RothRick AndersonShaun Luttin 提供

注意

這不是這篇文章的最新版本。 如需目前的版本,請參閱 本文的 .NET 9 版本。

警告

不再支援此版本的 ASP.NET Core。 如需詳細資訊,請參閱 .NET 和 .NET Core 支持原則。 如需目前的版本,請參閱 本文的 .NET 9 版本。

重要

這些發行前產品的相關資訊在產品正式發行前可能會有大幅修改。 Microsoft 對此處提供的資訊,不做任何明確或隱含的瑕疵擔保。

如需目前的版本,請參閱 本文的 .NET 9 版本。

ASP.NET Core 是一種跨平台且高效能的開放原始碼架構,用於建置新式、啟用雲端且連線網際網路的應用程式。

利用 ASP.NET Core,您可以:

  • 建置 Web 應用程式和服務、物聯網 (IoT) 應用程式,以及行動後端。
  • 在 Windows、macOS 和 Linux 上使用您最愛的開發工具。
  • 部署到雲端或在內部部署。
  • .NET 上執行。

為什麼要選擇 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 APIWeb 應用程式的功能:

用戶端開發

ASP.NET Core 包括用於建置豐富的互動式 Web UI 的 Blazor,同時也可與其他熱門的前端 JavaScript 架構整合,例如 AngularReactVueBootstrap。 如需詳細資訊,請參閱 ASP.NET Core Blazor 以及<用戶端開發>底下的相關主題。

ASP.NET Core 目標架構

ASP.NET Core 3.x 或更新版本只能以 .NET 為目標。

以 .NET 為目標有幾個優點,而這些優點會隨著每個版本的發行而增加。 .NET 相較於 .NET Framework 的一些優點包括:

  • 跨平台。 在 Windows、macOS 和 Linux 上執行。
  • 提升效能
  • 並存版本設定
  • 新的 API
  • 開放原始碼

建議使用下列一系列的教學課程,來取得開發 ASP.NET Core 應用程式的簡介:

  1. 遵循您想要開發或維護之應用程式類型的教學課程。

    應用程式類型 案例 教學課程
    Web 應用程式 新的伺服器端 Web UI 開發 開始使用 Razor Pages
    Web 應用程式 維護 MVC 應用程式 開始使用 MVC
    Web 應用程式 用戶端 Web UI 開發 開始使用 Blazor
    Web API RESTful HTTP 服務 建立 Web API
    遠端程序呼叫應用程式 使用通訊協定緩衝區的合約優先服務 開始使用 gRPC 服務
    即時應用程式 伺服器與已連線用戶端之間的雙向通訊 開始使用 SignalR
  2. 遵循顯示如何進行基本資料存取的教學課程。

    案例 教學課程
    新的開發 搭配 Entity Framework Core 的 Razor Pages
    維護 MVC 應用程式 搭配 Entity Framework Core 的 MVC
  3. 閱讀適用於所有應用程式類型的 ASP.NET Core 基礎概念

  4. 瀏覽其他感興趣主題的目錄。

†另外還有互動式 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 APIWeb 應用程式的功能:

用戶端開發

ASP.NET Core 可無縫地與熱門的用戶端架構和程式庫整合,包括 BlazorAngularReactVueBootstrap。 如需詳細資訊,請參閱 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 應用程式的簡介:

  1. 遵循您想要開發或維護之應用程式類型的教學課程。

    應用程式類型 案例 教學課程
    Web 應用程式 針對全新開發 開始使用 Razor Pages
    Web 應用程式 針對維護 MVC 應用程式 開始使用 MVC
    Web API 建立 Web API
    即時應用程式 開始使用 SignalR
  2. 遵循顯示如何進行基本資料存取的教學課程。

    案例 教學課程
    針對全新開發 搭配 Entity Framework Core 的 Razor Pages
    針對維護 MVC 應用程式 搭配 Entity Framework Core 的 MVC
  3. 閱讀適用於所有應用程式類型的 ASP.NET Core 基礎概念

  4. 瀏覽其他您感興趣主題的目錄。

†另外還有您可以在瀏覽器中完整遵循的 Web API 教學課程,而且不需要進行本機 IDE 安裝。 程式碼會在 Azure Cloud Shell 中執行,且會使用 curl 來進行測試。

從 .NET Framework 移轉

如需將 ASP.NET 應用程式移轉至 ASP.NET Core 的參考指南,請參閱從 ASP.NET 更新為 ASP.NET Core

如何下載範例

許多文章及教學課程都有包含範例程式碼的連結。

  1. 下載 ASP.NET 存放庫 ZIP 檔案
  2. AspNetCore.Docs-main.zip 檔案解壓縮。
  3. 若要存取已解壓縮存放庫中的文章範例應用程式,請使用文章範例連結中的 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# 參考)

中斷性變更和安全性諮詢

公告存放庫上會報告中斷性變更和安全性諮詢。 選取 [標籤] 篩選,以將公告限制為特定版本。

下一步

如需詳細資訊,請參閱以下資源: