Skip to the content.

HTTP Verbs

Just like the HTTP status codes, there are many more verbs in the HTTP standard that, although they are in theory OK to use for your Web API, you can get by with just a few that helps to keep your API simple, and self-explanatory to its clients.

The full list of HTTP verbs from the spec can be found HERE, but we are going to focus on how to interpret the verbs and the actions that should be executed for each on in the context of a well-defined REST Web API. In the table there is also the result set that standard clients expect when they make requests with such VERBs. To better understand their proper use, we’ll use a sample resource endpoint called Users, where the (you guessed it) “Users” of our app are exposed via our Web API.

Resource Sample   GET (Read) POST (Insert) PUT (update) DELETE Patch (partial update)
api/users Action Get a list of users Creates a user Batch update Error Batch update the users only with the attributes present in the request
  Return List of users New user No payload, only HTTP Status Code Error HTTP Status Code  
             
api/users/123 Action Get a single user Error Updates the user Deletes the user Partially updates the user only with the attributes present in the request
  Return Single user Error HTTP Status code Updated user No payload, only  

And this is how you properly use the HTTP Verbs in a REST Web API.

:information_source: This paragraph is mainly a copy from http://micheltriana.com/2013/09/30/http-verbs-in-a-rest-web-api/. Thanks to Michel Triana.