ASP.NET Core WebAPI Get Post Put Delete

HTTP 操作谓词CRUD 操作ASP.NET Core 属性
GET读取[HttpGet]
POST创建[HttpPost]
PUT更新[HttpPut]
DELETE删除[HttpDelete]

 

GET 获取数据

获取全部数据

[HttpGet]
public ActionResult<List<Pizza>> GetAll() =>
    PizzaService.GetAll();
  • 查询服务以获取所有披萨,并通过 Content-Type 的值 application/json 自动返回数据。

获取单个实例

[HttpGet("{id}")]
public ActionResult<Pizza> Get(int id)
{
    var pizza = PizzaService.Get(id);

    if(pizza == null)
        return NotFound();

    return pizza;
}
  • 要求 pizza/ 之后的 URL 段中包含 id 参数的值。 请记住,控制器级别的 /pizza 属性定义了 [Route] 模式。
  • 查询数据库以获取与所提供的 id 参数匹配的披萨。

上述操作中使用的每个 ActionResult 实例都映射到下表中对应的 HTTP 状态代码:

ASP.NET Core
操作结果
HTTP 状态代码说明
Ok 为隐式200内存中缓存中存在与所提供的 id 参数匹配的产品。
该产品包含在由 accept HTTP 请求标头中所定义的媒体类型(默认情况下为 JSON)的响应正文中。
NotFound404内存中缓存中不存在与所提供的 id 参数匹配的产品。

POST 新添

[HttpPost]
public IActionResult Create(Pizza pizza)
{            
    PizzaService.Add(pizza);
    return CreatedAtAction(nameof(Create), new { id = pizza.Id }, pizza);
}

CreatedAtAction 方法调用中的第一个参数表示操作名称。 nameof 关键字用于避免对操作名称进行硬编码。 CreatedAtAction 使用操作名称来生成 location HTTP 响应标头,该标头包含新创建的披萨的 URL

 此方法并不像我们在 Get() 方法中看到的那样返回披萨列表,而是返回 IActionResult 响应。IActionResult 可让客户端知道请求是否成功,并提供新创建的披萨的 ID。 IActionResult 通过使用标准 HTTP 状态代码来完成该操作,因此,无论客户端使用哪种语言或者在哪个平台上运行,它都能轻松地与客户端集成。

ASP.NET Core
操作结果
HTTP 状态代码说明
CreatedAtAction201已将披萨添加到内存中缓存。
该披萨包含在由 accept HTTP 请求标头中所定义的媒体类型(默认情况下为 JSON)的响应正文中。
BadRequest 为隐式400请求正文的 pizza 对象无效。

PUT 修改

[HttpPut("{id}")]
public IActionResult Update(int id, Pizza pizza)
{
    if (id != pizza.Id)
        return BadRequest();
           
    var existingPizza = PizzaService.Get(id);
    if(existingPizza is null)
        return NotFound();
   
    PizzaService.Update(pizza);           
   
    return NoContent();
}
  • 要求 pizza/ 之后的 URL 段中包含 id 参数的值。
  • 返回 IActionResult,因为在运行时之前,ActionResult 返回类型未知。 BadRequestNotFound 和 NoContent 方法分别返回 BadRequestResultNotFoundResult 和 NoContentResult 类型。
  • 由于控制器批注通过 [ApiController] 属性进行,因此暗示着将在请求正文中找到 Pizza 参数。
ASP.NET Core
操作结果
HTTP 状态代码说明
NoContent204已在内存中缓存中更新了披萨。
BadRequest400请求正文的 Id 值与路由的 id 值不匹配。
BadRequest 为隐式400请求正文的 Pizza 对象无效。

DELETE 删除

[HttpDelete("{id}")]
public IActionResult Delete(int id)
{
    var pizza = PizzaService.Get(id);
   
    if (pizza is null)
        return NotFound();
       
    PizzaService.Delete(id);
   
    return NoContent();
}
  • 要求 pizza/ 之后的 URL 段中包含 id 参数的值。
  • 返回 IActionResult,因为在运行时之前,ActionResult 返回类型未知。 NotFound 和 NoContent 方法分别返回 NotFoundResult 和 NoContentResult 类型。
ASP.NET Core
操作结果
HTTP 状态代码说明
NoContent204已从内存中缓存中删除了披萨。
NotFound404内存中缓存中不存在与所提供的 id 参数匹配的披萨。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ASP.NET Web API 是一个快速开发框架,用于构建用于Web应用程序的Web服务。它基于ASP.NET和HTTP协议,并充分利用了HTTP特性。 ASP.NET Web API 提供了一种简单明了的方式来创建和发布Web API,使开发人员能够轻松地将数据和服务暴露给客户端应用程序,无论是Web应用程序、移动应用程序还是其他类型的客户端。 ASP.NET Web API 提供了广泛的特性和功能,包括: 1. 灵活的路由配置:通过使用属性路由或传统的路由映射,开发人员可以轻松地定义API的URL结构和访问规则。 2. 内建HTTP支持:ASP.NET Web API完全支持HTTP协议,并提供了与HTTP相关的功能,如GETPOSTPUTDELETE等HTTP动词和状态码处理。 3. 内容协商:ASP.NET Web API 可以根据客户端的要求,动态选择并返回不同的响应内容类型,如JSON、XML或其他自定义媒体类型。 4. 模型绑定和验证:ASP.NET Web API 提供了强大的模型绑定和验证功能,可以自动将请求数据绑定到相应的模型并进行验证。 5. 信息路由和版本控制:ASP.NET Web API 支持信息路由和版本控制,可以根据不同的请求信息选择不同的版本和实现。 6. 异常处理:ASP.NET Web API 提供了全面的异常处理机制,可以捕获和处理各种异常,并返回友好和有效的错误信息给客户端。 7. 安全性和身份验证:ASP.NET Web API 支持各种身份验证和安全性机制,如基于角色的授权、OAuth 2.0等。 总之,ASP.NET Web API 提供了一个高效、灵活和可扩展的框架,使开发人员能够快速构建和发布Web服务,并能适应不同类型的客户端应用程序。无论是构建企业级应用程序还是移动应用程序,ASP.NET Web API 都能够提供稳定可靠的解决方案。 ### 回答2: ASP.NET WebAPI是一种基于ASP.NET框架的快速开发框架。它主要用于构建和发布RESTful的Web服务,使开发者能够更快速地创建可扩展、可用性高的WebAPI应用程序。 首先,ASP.NET WebAPI提供了开箱即用的特性,使得开发者能够快速地创建基于HTTP协议的API。它支持多种数据格式,如JSON和XML,以及多个身份验证和授权方式,如基于角色和令牌的身份验证,使得开发者可以根据项目需求选择合适的方式来保护API。 其次,ASP.NET WebAPI提供了丰富的路由和绑定特性,使得开发者能够通过简单的配置和属性标记来定义API的路由规则和参数绑定方式。这种灵活性和可配置性使得开发者能够更轻松地处理不同的请求和响应,并提供符合预期的结果。 另外,ASP.NET WebAPI还提供了强大的行为和过滤器特性,例如认证过滤器、授权过滤器和异常过滤器等,使得开发者能够在不同阶段对请求进行处理和验证。同时,开发者还可以通过自定义过滤器来扩展现有特性或添加新的行为和过滤器。 此外,ASP.NET WebAPI还提供了易于测试和部署的特性。开发者可以使用单元测试框架对API进行测试,并通过ASP.NET的集成测试工具进行端到端的测试。同时,ASP.NET WebAPI还支持自托管和IIS托管两种部署方式,使得开发者能够更方便地部署和维护API应用程序。 综上所述,ASP.NET WebAPI是一个功能强大、易于使用和高效的快速开发框架。它提供了丰富的特性和可扩展性,使开发者能够更快速地构建和发布高质量的WebAPI应用程序。 ### 回答3: ASP.NET Web API 是一个用于构建基于HTTP协议的Web服务的框架,它可以让开发人员更快速、更高效地开发Web应用程序。 首先,ASP.NET Web API 提供了快速创建和部署Web服务的能力。通过使用ASP.NET Web API,开发人员可以轻松地创建RESTful风格的API,并将其部署到云端或本地服务器上。与传统的ASP.NET MVC相比,ASP.NET Web API 提供了更简洁、更轻量级的开发体验,让开发人员可以更专注于服务端逻辑的编写。 其次,ASP.NET Web API 提供了丰富的功能和工具,帮助开发人员更快速地构建和调试Web服务。它支持多种数据格式,包括JSON和XML,提供了强大的序列化和反序列化功能,可以轻松地处理来自客户端的请求和响应数据。此外,ASP.NET Web API 还支持组织代码的特性,如路由、过滤器和模型绑定等,让开发人员可以更轻松地组织和管理代码。 最后,ASP.NET Web API 具有良好的可扩展性和灵活性。它可以很容易地和其他ASP.NET 项目集成,如ASP.NET MVC和ASP.NET Core等。开发人员可以利用现有的ASP.NET技术和工具来开发和扩展Web API,并利用ASP.NET的生态系统来提供更丰富的功能和支持。 总之,ASP.NET Web API 是一个快速开发框架,它提供了方便、高效的开发体验,让开发人员可以更快速地构建和部署基于HTTP协议的Web服务。无论是构建RESTful风格的API,还是处理来自客户端的请求和响应数据,ASP.NET Web API 都是一个强大的工具和框架。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值