AspNetCore.Docs/aspnetcore/includes/webApi/end.md

2.7 KiB

Implement the other CRUD operations

In the following sections, Create, Update, and Delete methods are added to the controller.

Create

Add the following Create method.

[!code-csharpMain]

The preceding code is an HTTP POST method, indicated by the [HttpPost] attribute. The [FromBody] attribute tells MVC to get the value of the to-do item from the body of the HTTP request.

The CreatedAtRoute method:

  • Returns a 201 response. HTTP 201 is the standard response for an HTTP POST method that creates a new resource on the server.
  • Adds a Location header to the response. The Location header specifies the URI of the newly created to-do item. See 10.2.2 201 Created.
  • Uses the "GetTodo" named route to create the URL. The "GetTodo" named route is defined in GetById:

[!code-csharpMain]

Use Postman to send a Create request

Postman console

  • Set the HTTP method to POST
  • Select the Body radio button
  • Select the raw radio button
  • Set the type to JSON
  • In the key-value editor, enter a Todo item such as
{
	"name":"walk dog",
	"isComplete":true
}
  • Select Send
  • Select the Headers tab in the lower pane and copy the Location header:

Headers tab of the Postman console

The Location header URI can be used to access the new item.

Update

Add the following Update method:

[!code-csharpMain]

Update is similar to Create, but uses HTTP PUT. The response is 204 (No Content). According to the HTTP spec, a PUT request requires the client to send the entire updated entity, not just the deltas. To support partial updates, use HTTP PATCH.

Postman console showing 204 (No Content) response

Delete

Add the following Delete method:

[!code-csharpMain]

The Delete response is 204 (No Content).

Test Delete:

Postman console showing 204 (No Content) response