422 Unprocessable Entity

The HTTP 422 status code means the server understands the response body but couldn’t process the request because there’s something wrong with the content.

While the request body (payload) can be technically correct, it can fail in different ways:

422 vs 400

If the client sends you a malformed or invalid JSON, you should return the 400 Bad Request. If the JSON itself is valid, but some fields aren’t, you should respond with 422 Unprocessable Entity.

Likewise, if the data client sends is valid but doesn’t pass server-specific validations, you should probably respond with 422.

For example, if you’re building an API for an e-commerce platform, 422 would be appropriate when the client:

Ruby on Rails

Rails responds with 422 Unprocessable Entity when the client fails to pass a CSRF check. There are two ways around this problem:

Starting from version 5.2, Rails automatically enables CSRF checks in all views/controllers. If you’re sending AJAX requests, you must explicitly include the X-CSRF-Token header:

'X-CSRF-Token': document.querySelector("meta[name=csrf-token]").content

You can disable the CSRF check for a particular controller by including the skip_before_action action.

class UsersController < ApplicationController
  skip_before_action :verify_authenticity_token
end

Note that this opens your app to a CSRF attack. You should only do this if you trust the input (for example, webhooks from a third-party API).