I have a REST endpoint for a search.
GET /person?firstname=john&name=smith
As result a collection with the HTTP status code 200 OK
is returned:
[
{
"id":11,
"firstname":"John",
"name":"Smith",
"birthday":"1996-03-08"
},
{
"id":18,
"firstname":"John",
"name":"Smith",
"birthday":"1963-07-11"
}
]
What is the correct HTTP status code and payload for a empty search result?
HTTP Status 200 OK
with a empty collection []
HTTP Status 204 No Content
with a empty collection []
HTTP Status 204 No Content
with a empty body
I would recommend:
HTTP Status 200 OK with a empty collection []
The reason is that 204 means there is no content to send back and that is not what the result of your call is.
In your case, there IS something to send back. It's a Json result that happens to be composed of an empty collection.
UPDATE:
From the HTTP protocol definition:
10.2.5 204 No Content: The server has fulfilled the request but does not need to return an entity-body, and might want to return updated metainformation.
And:
The 204 response MUST NOT include a message-body, and thus is always terminated by the first empty line after the header fields.