【Web API系列教程】3.2 — 实战:处理数据(添加模型和控制器)

简介: 前言在本部分中,你将添加用于定义数据库实体的模型类。然后你将添加用于在这些实体上执行CRUD(Create、Retrieve、Update、Delete——译者注)操作的Web API 控制器。

前言

在本部分中,你将添加用于定义数据库实体的模型类。然后你将添加用于在这些实体上执行CRUD(Create、Retrieve、Update、Delete——译者注)操作的Web API 控制器。

添加模型类

在本教程中,我们将通过使用“Code First”的方法对实体框架(EF)来创建数据库。对于Code First,你写C#类来相应数据库表,使用EF来创建数据库。(有关详细信息,见Entity Framework Development Approaches.)

首先,我们定义我们的域对象作为POCO。我们将创建以下POCO:
Author
Book

在解决方案资源管理中,右击Models文件夹。选择Add,然后选择Class。名为这个类为Author。

这里写图片描述

用以下代码替换Author.cs中的所有样板代码。

using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;

namespace BookService.Models
{
    public class Author
    {
        public int Id { get; set; }
        [Required]
        public string Name { get; set; }
    }
}

添加另一个命名为Book的类,并替换成以下代码。

using System.ComponentModel.DataAnnotations;

namespace BookService.Models
{
    public class Book
    {
        public int Id { get; set; }
        [Required]
        public string Title { get; set; }
        public int Year { get; set; }
        public decimal Price { get; set; }
        public string Genre { get; set; }

        // Foreign Key
        public int AuthorId { get; set; }
        // Navigation property
        public Author Author { get; set; }
    }
}

Entity Framework将使用这些模型来创建数据库表。对于每一个模型,Id属性将变成数据库表的主键列。

在Book类中,AuthorId定义了一个外键到Author表。(简单起见,我假定每本书只有一个作者。)该book类还包含一个导航属性给相关的Author。 你可以使用导航属性在代码中访问相关的作者。我在【Web API系列教程】3.4 — 实战:处理数据(处理实体关系)
中描述了关于导航属性的更多信息。

添加Web API 控制器

在这部分,我们将添加支持CRUD(create, read, update 和 delete)的Web API 控制器。这些控制器使用Entity Framework来同数据库层交流。

首先,你应该删除Controllers目录下的ValuesControllers.cs文件。这个文件包含了一个Web API示例,但对于本教程你并不需要它。

这里写图片描述

然后,编译这个项目。Web API框架使用反射来发现这个模型类,所以它需要编译程序集。

在Solution Explorer中,右击Controllers文件夹。选择Add,然后选择Controller。

这里写图片描述

在Add Scaffold对话框中,选择“Web API 2 controller with actions, using Entity Framework”。点击Add。

这里写图片描述

在Add Controller对话框中,执行以下操作:
1, 在模型类下拉框中,选择Author类。(如果你没有在下拉框中看到它,请确保已经编译了这个项目。)
2, 选中“Use async controller action”。
3, 保留控制器名称为“AuthorsController”。
4, 点击加号(+)按钮下一步到Data Context Class.

这里写图片描述

在New Data Context对话框中,保留默认名称并点击Add。

这里写图片描述

点击Add以完成Add Controller对话框。这个对话将添加两个类到你的项目中:
AuthorsController定义了一个Web API控制器。这个控制器实现了REST API,客户端使用它来在authors列表上执行CRUD操作。
BookServiceContext在运行时管理实体对象,包括从数据库中聚集对象数据、追踪、保留数据到数据库。它继承自DBContext。

这里写图片描述

在这个节点上,再次编译这个项目。现在再过一遍相同的步骤为Book实体添加API控制器。这次选择Book作为模型类,并选择已经存在的BookServiceContext类作为数据上下文类。(不要再创建新的数据上下文。)点击Add以添加该控制器。

这里写图片描述

目录
相关文章
|
15天前
|
Kubernetes 安全 Devops
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
39 10
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
|
7天前
|
弹性计算 Java 数据库
Web应用上云经典架构实战
本课程详细介绍了Web应用上云的经典架构实战,涵盖前期准备、配置ALB、创建服务器组和监听、验证ECS公网能力、环境配置(JDK、Maven、Node、Git)、下载并运行若依框架、操作第二台ECS以及验证高可用性。通过具体步骤和命令,帮助学员快速掌握云上部署的全流程。
|
9天前
|
安全 应用服务中间件 网络安全
实战经验分享:利用免费SSL证书构建安全可靠的Web应用
本文分享了利用免费SSL证书构建安全Web应用的实战经验,涵盖选择合适的证书颁发机构、申请与获取证书、配置Web服务器、优化安全性及实际案例。帮助开发者提升应用安全性,增强用户信任。
|
24天前
|
网络协议 API
检测指定TCP端口开放状态免费API接口教程
此API用于检测指定TCP端口是否开放,支持POST/GET请求。需提供用户ID、KEY、目标主机,可选指定端口(默认80)和地区(默认国内)。返回状态码、信息提示、检测主机、端口及状态(开放或关闭)。示例中ID和KEY为公共测试用,建议使用个人ID和KEY以享受更高调用频率。
42 14
|
25天前
|
API
获取网页状态码[可指定地域]免费API接口教程
该接口用于获取指定网址的访问状态码,支持从国内、香港、美国等地域节点访问。通过POST或GET请求,需提供用户ID、KEY及目标网址等参数。返回结果包括状态码和信息提示。 示例:https://cn.apihz.cn/api/wangzhan/getcode.php?id=88888888&key=88888888&type=1&url=www.apihz.cn。
|
25天前
|
缓存 算法 API
查询域名WHOIS信息免费API接口教程
该API用于查询顶级域名的WHOIS信息,不支持国别域名和中文域名。通过POST或GET请求,需提供用户ID、KEY及待查询域名。返回信息包括域名状态、注册商、时间等详细数据。示例与文档见官网。
|
25天前
|
API
icp备案查询免费API接口教程
该接口用于查询指定域名的ICP备案信息,支持POST或GET请求方式。请求时需提供用户ID、用户KEY及待查询的域名,可选参数为查询通道。响应中包含状态码、消息内容、备案号、备案主体、域名及审核时间等信息。示例中提供了GET和POST请求方式及返回数据样例。
|
24天前
|
前端开发 JavaScript API
提取网页所有链接免费API接口教程
此API用于提取指定网页内的所有链接信息并进行分类,支持POST和GET请求方式。需提供用户ID、KEY及目标网址等参数,可选指定访问节点。返回结果包括状态码、信息提示及各类链接集合,如图片、视频、文档等。示例中展示了请求格式与返回数据结构。
|
JSON 物联网 API
阿里云API芝士堂[物模型管理][模型]
将近一年没有关注阿里云物联网的api,最近看了下官网的文档,api列表中赫然多出了物模型的管理和使用两大类.这也难怪,物模型被誉为物联网世界的原子. 通过物模型可以有效的使用属性,服务和事件就可以表示出纷繁复杂和多姿多彩的物联网世界中的各种类型的设备;目前物模型并没有统一的规范,所以阿里,小米, 京东和中移动等大厂,都是各自制定一套自己的规范;阿里云这面主要是在自家的ICA联盟定义了一套物模型的规范.本文也从实践角度分享一下物模型相关api的使用.
501 0
|
13天前
|
人工智能 自然语言处理 API
Multimodal Live API:谷歌推出新的 AI 接口,支持多模态交互和低延迟实时互动
谷歌推出的Multimodal Live API是一个支持多模态交互、低延迟实时互动的AI接口,能够处理文本、音频和视频输入,提供自然流畅的对话体验,适用于多种应用场景。
62 3
Multimodal Live API:谷歌推出新的 AI 接口,支持多模态交互和低延迟实时互动