在这里,我们将创建一个新的Web API项目,它将使用实体框架实现Get,POST、PUT和DELETE方法来实现CRUD操作。

首先,在Visual Studio 2013 for Web express edition中创建一个新的Web API项目。

打开Visual Studio 2013 for Web点击文件菜单- >新建项目。这将打开新建项目弹窗如下所示。

在弹出的新将项目弹窗中,选择Visual C#下的Web模板。输入项目名称WebApiDemo并选择你想要创建的项目的位置。单击OK继续。这将打开一个弹窗选择一个项目模板。选择Web API项目如下所示。

在这里,在我们的演示项目中我们不会使用任何身份验证。所以,点击Change Authentication按钮来打开验证弹窗,并选择No Authentication单选按钮,然后单击OK,如下所示。

现在,在新建项目弹窗单击OK, 创建项目如下所示。

正如你所看到的,创建了一个新的WebApiDemo项目和所有必要的文件。

它也默认添加了ValuesController控制器,可以删除默认的ValuesController,因为我们将添加新的Web API控制器。

在这里,我们要使用实体框架DB-First方法访问数据库现有的School数据库。

所以,让我们使用DB First方法加入School数据库的EF 数据模型。

正如你所看到的,创建了一个新的WebApiDemo项目和所有必要的文件。它也默认添加了ValuesController控制器,可以删除默认的ValuesController,因为我们将添加新的Web API控制器。

在这里,我们要使用实体框架DB-First方法访问数据库现有的School数据库。所以,让我们使用DB First方法加入School数据库的EF 数据模型。


添加Entity Framework数据Model

使用DB-First方法加入Entity Framework数据模型,右键单击您的项目- >点击New Item..这将打开添加新项弹窗如下所示。

在左窗格中选择"Data"并在中间窗口“ADO.NET Entity Data Model ”,输入一个数据模型的名称,单击Add。这将打开实体数据模型向导,使用它可以为现有的School数据库生成实体数据模型。本教程的主题是讲解Web API,对于Entity Framework方面的知识,可以点击这里了解更多关于EntityFramework的教程。

完成所有实体数据模型向导的步骤后,EntityFramework将生成以下数据模型。

EntityFramework还生成了实体和上下文类,如下所示。

现在,我们已经准备好了在我们的Web API项目中使用实体框架实现CRUD的操作。现在,让我们在我们的项目中添加一个Web API控制器。


添加Web API 控制器

在MVC项目中添加一个Web API控制器,右键单击Controllers文件夹或另一个你想添加一个Web API控制器的文件夹- >选择add - >选择Controller。这将打开Add Scaffold弹窗如下所示。

在Add Scaffold 弹窗,在左窗格中选择Web API,在中间窗格中选择Web API 2 Controller - Empty,单击Add。(我们选择空模板作为添加Action方法。)

这将打开Add Controller弹窗,你需要输入控制器的名称。输入“StudentController”作为控制器名称并单击添加如下所示。

这将添加继承自ApiController的空的StudentController类如下所示。

1
2
3
4
5
6
7
8
9
10
11
12
13
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Web.Http;
namespace MyMVCApp.Controllers
{
    public class StudentController : ApiController
    {
     
    }
}

在随后的教程中,我们将在该控制器中实现GET、POST、PUT和DELETE操作方法。


添加Model

我们将使用实体框架(EF)访问底层数据库。如您所见,EF创建了自己的实体类。理想情况下,我们不应该从Web API返回EF实体对象。建议从Web API返回DTO(数据传输对象)。由于我们创建的Web API项目带有MVC功能,我们也可以使用MVC模型类,MVC模型类可以同时被MVC和Web API使用。

在这个Web API项目中,我们将Student, Address 和 Standard 。所以,在Models创建StudentViewModel AddressViewModel和StandardViewModel模型如下所示。

以下是模型类。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public class StudentViewModel
{
    public int Id { getset; }
    public string FirstName { getset; }
    public string LastName { getset; }
         
    public AddressViewModel Address { getset; }
    public StandardViewModel Standard { getset; }
}
public class StandardViewModel
{
    public int StandardId { getset; }
    public string Name { getset; }
    public ICollection<StudentViewModel> Students { getset; }
public class AddressViewModel
{
    public int StudentId { getset; }
    public string Address1 { getset; }
    public string Address2 { getset; }
    public string City { getset; }
    public string State { getset; }
}

注意:ViewModel类或DTO类只是为了从Web API控制器数据传输到客户端。你可以根据你的选择命名。

转载于:https://www.cnblogs.com/zxh1919/p/7873906.html

创建包含CRUD操作的Web API接口-第一部相关推荐

  1. 不使用jQuery对Web API接口POST,PUT,DELETE数据

    前些天,Insus.NET有演示Web API接口的操作: <怎样操作WebAPI接口(显示数据)>http://www.cnblogs.com/insus/p/5670401.html ...

  2. Web API接口开发和测试

    4.ASP.NET Web API的开发 上面我们定义了一般的Web API接口,以及实现相应的业务实现,如果我们需要创建Web API层,还需要构建一个Web API项目的. 创建好相应的项目后,可 ...

  3. rap2检测哪些接口在使用_使用RAP2和Mock.JS实现Web API接口的数据模拟和测试

    最近一直在思考如何对Web API的其接口数据进行独立开发的问题,随着Web API的越来越广泛应用,很多开发也要求前端后端分离,例如统一的Web API接口后,Winform团队.Web前端团队.微 ...

  4. ASP.NET Web API 接口执行时间监控

    软件产品常常会出现这样的情况:产品性能因某些无法预料的瓶颈而受到干扰,导致程序的处理效率降低,性能得不到充分的发挥.如何快速有效地找到软件产品的性能瓶颈,则是我们感兴趣的内容之一. 在本文中,我将解释 ...

  5. 调用JShaman的Web API接口,实现JS代码加密。

    在NodeJS中,调用JShaman的Web API接口,实现JS代码加密. 同样的方法,也可把该功能集成到自己的产品或项目中,让自己也具备JS加密功能. 调用JShaman接口的源码非常简单: /* ...

  6. 鸿蒙开发访问webapi,Web API接口

    #e# 3.集合和分页的处理 在很多接口里面,我们都需要用到分页的处理,Web API也不例外,这样可以提交数据检索效率,减少服务器数据处理的压力,同时也提交客户端的数据显示速度. 一般的集合接口定义 ...

  7. Web API接口鉴权方式

    一.什么是鉴权?为什么要鉴权 鉴权(authentication),也叫做认证,即验证用户是否拥有访问系统的权利. HTTP本身是无状态的请求,每次请求都是一次性的,并不会知道请求前后发生了什么.但在 ...

  8. web api接口开发实例_C# 物联网开发API接口系列(4)

    C# 物联网开发API接口系列(四) #久爱物联网#MQTT# [提纲] 1)获取设备列表(某用户的) 2)单独检查设备是否存在合法 [正文] /// /// 获取设备列表 /// /// 令牌 // ...

  9. WebApi系列~通过HttpClient来调用Web Api接口

    HttpClient是一个被封装好的类,主要用于Http的通讯,它在.net,java,oc中都有被实现,当然,我只会.net,所以,只讲.net中的HttpClient去调用Web Api的方法,基 ...

最新文章

  1. kernel笔记——内核编译与进程管理
  2. 用户名 不在 sudoers文件中,此事将被报告
  3. springboot特点
  4. c# 学习笔记 (1) 类型转换
  5. ML之多分类预测之PLiR:使用PLiR实现对六类label数据集进行多分类
  6. IOS小技巧–用runtime 解决UIButton 重复点击问题
  7. 审计文件的作用以及记录的内容,审计日志的记录,以及审计日志包括的内容
  8. php get请求 json返回,[1.23]-请求和响应:GET和POST两者皆可得及超越JSON格式返回 | PhalApi(π框架) - PHP轻量级开源接口框架 - 接口,从简单开始!...
  9. 【数字逻辑设计】Logisim构建抢答环节电路
  10. 【Anaconda安装包】如何在Ananconda环境下安装CV2(opencv)
  11. matlab设置ga算法,matlab遗传算法ga函数
  12. lg g3 android 5.0,lg g3 5.0 root教程_lg g3获取5.0系统的root方法
  13. 【博客目录】成为一个优秀的数据工程师
  14. GitHub的简介翻译(草稿)
  15. IE浏览器调用jquery需要注意的小问题
  16. 明尼苏达量表结果分析_MMPI明尼苏达多项人格心理测试量表结果分析
  17. 道教的精神———闻一多
  18. 有趣题目和认知合集(持续更新)
  19. 2022最新在线工单管理系统源码+PHP内核
  20. python美化excel_Python 使用 prettytable 库打印表格(美化输出)

热门文章

  1. xen挂载虚拟机分区删除日志 破解密码无所不能
  2. C++ 的复制构造函数
  3. 在C#用GDI+实现图形图像的任意变形效果(转载)
  4. C#学习笔记:多态与隐藏,覆盖
  5. centos6.9安装Tomcat8.0.36
  6. ssm+mysql+jsp打造在线考试系统WeKnow-学生端
  7. 5.5.4 函数内部属性
  8. 广州图书馆借阅抓取——httpClient的使用
  9. python操作webservices
  10. AlertDialog 宽度充满整个屏幕