翻译自 Mohamad Lawand 2021年1月19日的文章 《Asp.Net Core 5 Rest API Step by Step》 [1]

在本文中,我们将创建一个简单的 Asp.Net Core REST API Todo 应用程序,在其中我们可以添加、编辑、删除和查看待办事项,并且将使用 SQLite 来存储数据。

你也可以在 YouTube 上观看完整的视频[2],还可以下载源代码[3]

这是 API 开发系列的第一部分,后面还有:

在开始之前,我们需要准备的四样东西:

下载并安装了所有必需的工具后,我们需要确保 dotnet SDK 已成功安装,我们需要打开终端并通过检查 dotnet 版本来检查 dotnet SDK 是否已成功安装。

打开终端并输入以下命令:

  1. dotnet --version

现在,我们需要安装 EntityFramework 工具:

  1. dotnet tool install --global dotnet-ef

完成后,我们需要创建我们的应用程序:

  1. dotnet new webapi -n "TodoApp" -lang "C#" -au none

现在让我们添加需要使用的依赖包,以便可以使用 EntityFramrwork 和 SQLite:

  1. dotnet add package Microsoft.EntityFrameworkCore.Sqlite
  2. dotnet add package Microsoft.EntityFrameworkCore.Tools

现在,请打开 VS Code 并检查我们的应用程序和源代码,然后,让我们构建应用程序并查看其是否可以运行:

  1. dotnet build
  2. dotnet run

确认可以正常运行后,我们删除由 .Net Core 框架为我们生成的默认模板代码,即删除 WeatherForcastController 和WeatherForcast 类。

接着,我们创建自己的控制器,将其命名为 TodoController

然后,我们创建第一个简单的 Action,将其命名为 TestRun,让我们开始为我们的控制器编码:

  1. [Route("api/[controller]")] // 我们定义控制器要使用的路由
  2. [ApiController] // 我们需要指定控制器的类型以让 .Net Core 知道
  3. public class TodoController : ControllerBase
  4. {
  5. [Route("TestRun")] // 定义此 Action 的路由
  6. [HttpGet]
  7. public ActionResult TestRun()
  8. {
  9. return Ok("success");
  10. }
  11. }

创建完成后,我们需要对其进行测试,为了测试,我们需要执行以下操作:

  1. dotnet build
  2. dotnet run

应用程序运行起来后,我们可以打开 Postman 试一下看看我们得到的响应。

我们在 Postman 中创建一个新请求,并将类型设置为 GET,然后请求以下 URL:

  1. https://localhost:5001/api/todo/testrun

正如您在 TestRun 中看到的那样,我们在 Postman 中得到了 “success” 响应。

测试完之后,我们现在需要开始添加模型,在根目录中添加一个 Models 文件夹,并在其中添加一个名为 ItemData 的类。这是一个非常简单的模型,它表示我们的待办事项的列表项。

  1. public class ItemData
  2. {
  3. public int Id { get; set; }
  4. public string Title { get; set; }
  5. public string Description { get; set; }
  6. public bool Done { get; set; }
  7. }

添加好模型后,我们需要构建 ApiDbContext。在根目录中创建一个 Data 文件夹,然后在该文件夹中创建一个名为 ApiDbContext 的新类。

  1. public class ApiDbContext : DbContext
  2. {
  3. public virtual DbSet<ItemData> Items {get;set;}
  4. public ApiDbContext(DbContextOptions<ApiDbContext> options)
  5. : base(options)
  6. {
  7. }
  8. }

然后,我们需要在 appsetting.json 中指定应用程序的连接字符串:

  1. "ConnectionStrings": {
  2. "DefaultConnection" : "DataSource=app.db; Cache=Shared"
  3. }

完善 DbContext 和连接字符串后,我们需要更新 Startup 类,以便可以在应用程序中使用 Application DbContext。在我们的根目录中打开 Startup 类,然后添加以下代码:

  1. services.AddDbContext<ApiDbContext>(options =>
  2. options.UseSqlite(
  3. Configuration.GetConnectionString("DefaultConnection")
  4. ));

添加好 DbContext 中间件后,我们需要添加初始化迁移来创建数据库:

  1. dotnet ef migrations add "Initial Migrations"
  2. dotnet ef database update

成功完成数据库更新后,我们可以看到有一个名为 Migrations 的新文件夹,它将包含 C# 脚本,该脚本将负责创建数据库及其表 Items。我们可以在根目录中看到 app.db 文件,也可以使用 SQLite 查看工具来验证表是否已成功创建,由此我们可以验证数据库是否已创建。

现在,我们已经完成了控制器的所有基础设施的搭建。现在,我们需要开始构建 TodoController 并将其连接到ApiDbContext

我们从添加获取待办事项中的所有项的方法 GetItems 开始,依次添加所有需要的方法:

  1. using System.Threading.Tasks;
  2. using Microsoft.AspNetCore.Mvc;
  3. using Microsoft.EntityFrameworkCore;
  4. using TodoApp.Data;
  5. using TodoApp.Models;
  6. namespace TodoApp.Controllers
  7. {
  8. [Route("api/[controller]")] // api/todo
  9. [ApiController]
  10. public class TodoController : ControllerBase
  11. {
  12. private readonly ApiDbContext _context;
  13. public TodoController(ApiDbContext context)
  14. {
  15. _context = context;
  16. }
  17. [HttpGet]
  18. public async Task<IActionResult> GetItems()
  19. {
  20. var items = await _context.Items.ToListAsync();
  21. return Ok(items);
  22. }
  23. [HttpPost]
  24. public async Task<IActionResult> CreateItem(ItemData data)
  25. {
  26. if (ModelState.IsValid)
  27. {
  28. await _context.Items.AddAsync(data);
  29. await _context.SaveChangesAsync();
  30. return CreatedAtAction("GetItem", new { data.Id }, data);
  31. }
  32. return new JsonResult("Something went wrong") { StatusCode = 500 };
  33. }
  34. [HttpGet("{id}")]
  35. public async Task<IActionResult> GetItem(int id)
  36. {
  37. var item = await _context.Items.FirstOrDefaultAsync(x => x.Id == id);
  38. if (item == null)
  39. return NotFound();
  40. return Ok(item);
  41. }
  42. [HttpPut("{id}")]
  43. public async Task<IActionResult> UpdateItem(int id, ItemData item)
  44. {
  45. if (id != item.Id)
  46. return BadRequest();
  47. var existItem = await _context.Items.FirstOrDefaultAsync(x => x.Id == id);
  48. if (existItem == null)
  49. return NotFound();
  50. existItem.Title = item.Title;
  51. existItem.Description = item.Description;
  52. existItem.Done = item.Done;
  53. // 在数据库级别实施更改
  54. await _context.SaveChangesAsync();
  55. return NoContent();
  56. }
  57. [HttpDelete("{id}")]
  58. public async Task<IActionResult> DeleteItem(int id)
  59. {
  60. var existItem = await _context.Items.FirstOrDefaultAsync(x => x.Id == id);
  61. if (existItem == null)
  62. return NotFound();
  63. _context.Items.Remove(existItem);
  64. await _context.SaveChangesAsync();
  65. return Ok(existItem);
  66. }
  67. }
  68. }

然后,我们可以在 Postman 中一个一个地对它们进行测试。

最后,由于我们在创建 Web API 项目时使用的是 .Net 5,因此 Swagger 已经集成到了我们的应用程序中,要查看 Swagger 界面,可以在浏览器中导航到 http://localhost:5000/swagger/index.html

Swagger 允许您描述 API 的结构,以便程序可以自动读取它们,而无需我们额外的工作。Swagger 能够读取 API 结构并为我们生成一个 UI,我们可以借此来改善开发体验。

感谢您阅读本文。

本文是 API 开发系列的第一部分,后面会有第二、第三部分。

作者 : Mohamad Lawand

译者 : 技术译民

出品 : 技术译站

链接 : 英文原文


  1. https://dev.to/moe23/asp-net-core-5-rest-api-step-by-step-2mb6 Asp.Net Core 5 Rest API Step by Step

  2. https://youtu.be/p_wUdWshYc8

  3. https://github.com/mohamadlawand087/v6-RestApiNetCore5

  4. https://mp.weixin.qq.com/s/zR0Yz0eUYXzSrctYmE2oWg Asp.Net Core 5 REST API 使用 JWT 身份验证 - Step by Step

Asp.Net Core 5 REST API - Step by Step的更多相关文章

  1. Asp.Net Core 5 REST API 使用 JWT 身份验证 - Step by Step

    翻译自 Mohamad Lawand 2021年1月22日的文章 <Asp Net Core 5 Rest API Authentication with JWT Step by Step> ...

  2. Asp Net Core 5 REST API 使用 RefreshToken 刷新 JWT - Step by Step

    翻译自 Mohamad Lawand 2021年1月25日的文章 <Refresh JWT with Refresh Tokens in Asp Net Core 5 Rest API Step ...

  3. angular4和asp.net core 2 web api

    angular4和asp.net core 2 web api 这是一篇学习笔记. angular 5 正式版都快出了, 不过主要是性能升级. 我认为angular 4还是很适合企业的, 就像.net ...

  4. ASP.NET Core 中基于 API Key 对私有 Web API 进行保护

    这两天遇到一个应用场景,需要对内网调用的部分 web api 进行安全保护,只允许请求头账户包含指定 key 的客户端进行调用.在网上找到一篇英文博文 ASP.NET Core - Protect y ...

  5. ASP.NET Core WebApi构建API接口服务实战演练

    一.ASP.NET Core WebApi课程介绍 人生苦短,我用.NET Core!提到Api接口,一般会想到以前用到的WebService和WCF服务,这三个技术都是用来创建服务接口,只不过Web ...

  6. 使用ASP.NET Core构建RESTful API的技术指南

    译者荐语:利用周末的时间,本人拜读了长沙.NET技术社区翻译的技术标准<微软RESTFul API指南>,打算按照步骤写一个完整的教程,后来无意中看到了这篇文章,与我要写的主题有不少相似之 ...

  7. 温故知新,使用ASP.NET Core创建Web API,永远第一次

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

  8. 使用angular4和asp.net core 2 web api做个练习项目(一)

    这是一篇学习笔记. angular 5 正式版都快出了, 不过主要是性能升级. 我认为angular 4还是很适合企业的, 就像.net一样. 我用的是windows 10 安装工具: git for ...

  9. 使用angular4和asp.net core 2 web api做个练习项目(四)

    第一部分: http://www.cnblogs.com/cgzl/p/7755801.html 第二部分: http://www.cnblogs.com/cgzl/p/7763397.html 第三 ...

随机推荐

  1. css & object-fit & background-image

    css & object-fit & background-image object-fit /*default fill */ object-fit: fill|contain|co ...

  2. c++ 遍历当前程序的线程

    #include <iostream> #include <Windows.h> #include <Psapi.h> #include <TlHelp32. ...

  3. perl 在windows上获取当前桌面壁纸

    更多 #!/usr/bin/perl # 在windows获取当前的桌面壁纸 # See also: https://www.winhelponline.com/blog/find-current-w ...

  4. jetty的jndi

    jetty的jndi和tomcat的用法 tomcat的jndi是内置的,在web.xml文件里直接默认支持的,所有web项目可以直接使用 <resources> <!-- < ...

  5. python中的enumerate 函数(编号的实现方式)

    enumerate 函数用于遍历序列中的元素以及它们的下标: 默认从0开始,如果想从1开始,可以仿照最后案例 加上逗号,和数字编号 >>> for i,j in enumerate( ...

  6. RocketMQ同一个消费者唯一Topic多个tag踩坑经历

    最近做的项目的一个版本需求中,需要用到MQ,对数据记录进行异步落库,这样可以减轻数据库的压力,同时可以抗住大量的数据落库.这里需要说明一下本人用到的MQ是公司自己在阿里的RokectMQ的基础上进行封 ...

  7. 微信小程序:post请求参数放在请求体中还是拼接到URL中需要看后台是如何接收的

    前端发送post请求时,请求参数可以放在请求中,代码如下: function post(url, data, callback) { wx.request({ method: 'POST', url: ...

  8. Kubernetes中分布式存储Rook-Ceph部署快速演练

    最近在项目中有涉及到Kubernetes的分布式存储部分的内容,也抽空多了解了一些.项目主要基于Rook-Ceph运行,考虑到Rook-Ceph部署也不那么简单,官方文档的步骤起点也不算低,因此,在整 ...

  9. Vue3.0+Electron聊天室|electron跨平台仿QQ客户端|vue3.x聊天应用

    基于vue3+electron11跨端仿制QQ桌面应用实战Vue3ElectronQchat. 使用vue3+electron+vuex4+ant-design-vue+v3scroll+v3laye ...

  10. 后端程序员之路 20、python复习

    Welcome to Python.orghttps://www.python.org/ 怎么用最短时间高效而踏实地学习 Python? - 知乎https://www.zhihu.com/quest ...