401

Unauthorized

4xx Client Error Authentication is required and has failed or not been provided

Code Examples

Here are examples of how to test HTTP 401 responses in different programming languages:

Select options below to see how to use advanced features in your code:

Request:
curl https://free.mockerapi.com/401
Response Body:
{
  "success": false,
  "status": 401,
  "statusText": "Unauthorized - Authentication is required and has failed or not been provided",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/401",
    "fullUrl": "https://free.mockerapi.com/401"
  }
}
Request:
fetch('https://free.mockerapi.com/401')
  .then(response => {
    console.log('Status:', response.status); // 401
    return response.json();
  })
  .then(data => {
    console.log('Response:', data);
  })
  .catch(error => {
    console.error('Error:', error);
  });
Response Body:
{
  "success": false,
  "status": 401,
  "statusText": "Unauthorized - Authentication is required and has failed or not been provided",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/401",
    "fullUrl": "https://free.mockerapi.com/401"
  }
}
Request:
import requests

response = requests.get('https://free.mockerapi.com/401')

print(f'Status Code: {response.status_code}')  # 401
print(f'Response: {response.json()}')
Response Body:
{
  "success": false,
  "status": 401,
  "statusText": "Unauthorized - Authentication is required and has failed or not been provided",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/401",
    "fullUrl": "https://free.mockerapi.com/401"
  }
}
Request:
Response Body:
{
  "success": false,
  "status": 401,
  "statusText": "Unauthorized - Authentication is required and has failed or not been provided",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/401",
    "fullUrl": "https://free.mockerapi.com/401"
  }
}
Request:
require 'net/http'
require 'json'

uri = URI('https://free.mockerapi.com/401')
response = Net::HTTP.get_response(uri)

puts "Status Code: #{response.code}"  # 401
puts "Response: #{JSON.parse(response.body)}"
Response Body:
{
  "success": false,
  "status": 401,
  "statusText": "Unauthorized - Authentication is required and has failed or not been provided",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/401",
    "fullUrl": "https://free.mockerapi.com/401"
  }
}
Request:
package main

import (
    "fmt"
    "io"
    "net/http"
)

func main() {
    resp, err := http.Get("https://free.mockerapi.com/401")
    if err != nil {
        panic(err)
    }
    defer resp.Body.Close()

    fmt.Printf("Status Code: %d\n", resp.StatusCode)  // 401

    body, err := io.ReadAll(resp.Body)
    if err != nil {
        panic(err)
    }

    fmt.Printf("Response: %s\n", body)
}
Response Body:
{
  "success": false,
  "status": 401,
  "statusText": "Unauthorized - Authentication is required and has failed or not been provided",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/401",
    "fullUrl": "https://free.mockerapi.com/401"
  }
}
Request:
import java.net.http.*;
import java.net.URI;

public class HttpStatusTest {
    public static void main(String[] args) throws Exception {
        HttpClient client = HttpClient.newHttpClient();
        HttpRequest request = HttpRequest.newBuilder()
            .uri(URI.create("https://free.mockerapi.com/401"))
            .GET()
            .build();

        HttpResponse response = client.send(request,
            HttpResponse.BodyHandlers.ofString());

        System.out.println("Status Code: " + response.statusCode());  // 401
        System.out.println("Response: " + response.body());
    }
}
Response Body:
{
  "success": false,
  "status": 401,
  "statusText": "Unauthorized - Authentication is required and has failed or not been provided",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/401",
    "fullUrl": "https://free.mockerapi.com/401"
  }
}
Request:
const https = require('https');

https.get('https://free.mockerapi.com/401', (res) => {
  console.log('Status Code:', res.statusCode);  // 401

  let data = '';

  res.on('data', (chunk) => {
    data += chunk;
  });

  res.on('end', () => {
    console.log('Response:', JSON.parse(data));
  });
}).on('error', (err) => {
  console.error('Error:', err.message);
});
Response Body:
{
  "success": false,
  "status": 401,
  "statusText": "Unauthorized - Authentication is required and has failed or not been provided",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/401",
    "fullUrl": "https://free.mockerapi.com/401"
  }
}

What is HTTP 401 Unauthorized?

HTTP 401 Unauthorized indicates that the server cannot or will not process the request due to something that is perceived to be a client error. This could be malformed request syntax, invalid request message framing, or deceptive request routing.

The client should not repeat the request without modifications.

When Does This Happen?

A 401 Unauthorized response is returned when:

  • The request has invalid syntax or malformed request parameters
  • Required parameters are missing from the request
  • The request body contains invalid JSON or XML
  • Query parameters have invalid values or formats
  • The request URL is malformed or contains invalid characters
  • Request headers contain invalid or conflicting values

Try It Live

Click the button below to make a live request and see the 401 Unauthorized response

Common Use Cases

🔍 Input Validation Testing

Test how your application handles invalid input data and displays appropriate error messages to users.

🛡️ Error Handling

Ensure your application properly catches and handles bad request errors without crashing.

📝 Form Validation

Test form validation logic and ensure users receive clear feedback about invalid submissions.

🔄 API Testing

Verify that your API correctly validates request parameters and returns appropriate error responses.

🎨 UI/UX Development

Design and test error states in your user interface for invalid requests.

📚 Documentation

Provide examples of bad request scenarios in API documentation for developers.

Related Client Error Status Codes