ASP.NET Core 简介

作者:Daniel RothRick Anderson 和 Shaun Luttin

ASP.NET Core 是一个跨平台的高性能开源框架,用于生成启用云且连接 Internet 的新式应用。 使用 ASP.NET Core,您可以:

  • 生成 Web 应用和服务、物联网 (IoT) 应用和移动后端。

  • 在 Windows、macOS 和 Linux 上使用喜爱的开发工具。

  • 部署到云或本地。

  • 在 .NET Core 上运行。

为何选择 ASP.NET Core?

数百万开发人员在使用或使用过 ASP.NET 4.x 创建 Web 应用。 ASP.NET Core 是对 ASP.NET 4.x 的重新设计,其中包括体系结构上的更改,产生了更精简、更模块化的框架。

ASP.NET Core 具有如下优点:

使用 ASP.NET Core MVC 生成 Web API 和 Web UI

ASP.NET Core MVC 提供生成 Web API 和 Web 应用所需的功能:

客户端开发

ASP.NET Core 与常用客户端框架和库(包括 BlazorAngularReact 和 Bootstrap)无缝集成。 有关详细信息,请参阅 ASP.NET Core Blazor 简介 和“客户端开发”下的相关主题。

ASP.NET Core 目标框架

ASP.NET Core 3.x 和更高版本只能面向 .NET Core。 通常,ASP.NET Core 由 .NET Standard 库组成。 使用 .NET Standard 2.0 编写的库在实现 .NET Standard 2.0 的任何 .NET 平台上运行。

面向 .NET Core 有以下几个优势,并且这些优势会随着每次发布增加。 与 .NET Framework 相比,.NET Core 的部分优势包括:

  • 跨平台。 在 Windows、macOS 和 Linux 上运行。

  • 性能更强

  • 并行版本控制

  • 新 API

  • 开源

建议通过以下一系列教程来了解如何开发 ASP.NET Core 应用:

  1. 按照你要开发或维护的应用类型的教程操作:

    表 1
    应用类型方案教程
    Web 应用新的服务器端 Web UI 开发Razor Pages 入门
    Web 应用维护 MVC 应用MVC 入门
    Web 应用客户端 Web UI 开发开始使用 Blazor
    Web APIRESTful HTTP 服务创建 Web API
    远程过程调用应用使用协议缓冲区的协定优先服务开始使用 gRPC 服务
    实时应用服务器和连接的客户端之间的双向通信开始使用 SignalR
  2. 按照介绍如何进行基本数据访问的教程操作。

    表 2
    方案教程
    新的开发带 Entity Framework Core 的 Razor 页面
    维护 MVC 应用结合使用 MVC 和 Entity Framework Core
  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

如何下载示例

很多文章和教程中都包含有示例代码链接。

  1. 下载 ASP.NET 存储库 zip 文件

  2. 解压缩 AspNetCore.Docs-main.zip 文件。

  3. 若要在解压缩的存储库中访问文章的示例应用,请借助文章的示例链接中的 URL 来导航到示例文件夹。 通常,文章的示例链接显示在文章顶部,链接文本为“查看或下载示例代码”。

示例代码中的预处理器指令

为了演示多个方案,示例应用使用 #define 和 #if-#else/#elif-#endif 预处理器指令选择性地编译和运行示例代码中不同的片段。 对于那些利用此方法的示例,请将 C# 文件顶部的 #define 指令设置为定义与你想要运行的方案相关联的符号。 一些示例要求在多个文件的顶部定义符号才能运行方案。

例如,以下 #define 符号列表指示四个方案可用(每个符号一个方案)。 当前示例配置运行 TemplateCode 方案:

C#
#define TemplateCode // or LogFromMain or ExpandDefault or FilterInCode

若要更改示例以运行 ExpandDefault 方案,请定义 ExpandDefault 符号并保留剩余的符号处于被注释掉的状态:

C#
#define ExpandDefault // TemplateCode or LogFromMain or FilterInCode

若要详细了解如何使用 C# 预处理器指令选择性地编译代码段,请参阅 #define(C# 参考)和 #if(C# 参考)

示例代码中的区域

一些示例应用包含由 #region 和 #endregion C# 指令包围的代码片段。 文档生成系统会将这些区域注入到所呈现的文档主题中。

区域名称通常包含“代码段”一词。 下面的示例显示了一个名为 snippet_WebHostDefaults 的区域:

C#
#region snippet_WebHostDefaults
Host.CreateDefaultBuilder(args)
    .ConfigureWebHostDefaults(webBuilder =>
    {
        webBuilder.UseStartup<Startup>();
    });
#endregion

主题的 Markdown 文件在以下行中引用了前面的 C# 代码片段:

Markdown
[!code-csharp[](sample/SampleApp/Program.cs?name=snippet_WebHostDefaults)]

可放心忽略(或删除)代码两侧的 #region 和 #endregion 指令。 如果计划运行主题中所述的示例方案,请不要更改这些指令中的代码。 试用其他方案时,可随时更改代码。

有关详细信息,请参阅参与 ASP.NET 文档:代码片段

重大更改和安全建议

公告存储库上报告了重大更改和安全建议。 可以通过选择“标签”筛选器将公告限制为特定版本。

后续步骤

有关更多信息,请参见以下资源: