405

Method Not Allowed

4xx Client Error The request method is not supported for the requested resource

Code Examples

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

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

Request:
curl https://free.mockerapi.com/405
Response Body:
{
  "success": false,
  "status": 405,
  "statusText": "Method Not Allowed - The request method is not supported for the requested resource",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/405",
    "fullUrl": "https://free.mockerapi.com/405"
  }
}
Request:
fetch('https://free.mockerapi.com/405')
  .then(response => {
    console.log('Status:', response.status); // 405
    return response.json();
  })
  .then(data => {
    console.log('Response:', data);
  })
  .catch(error => {
    console.error('Error:', error);
  });
Response Body:
{
  "success": false,
  "status": 405,
  "statusText": "Method Not Allowed - The request method is not supported for the requested resource",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/405",
    "fullUrl": "https://free.mockerapi.com/405"
  }
}
Request:
import requests

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

print(f'Status Code: {response.status_code}')  # 405
print(f'Response: {response.json()}')
Response Body:
{
  "success": false,
  "status": 405,
  "statusText": "Method Not Allowed - The request method is not supported for the requested resource",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/405",
    "fullUrl": "https://free.mockerapi.com/405"
  }
}
Request:
Response Body:
{
  "success": false,
  "status": 405,
  "statusText": "Method Not Allowed - The request method is not supported for the requested resource",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/405",
    "fullUrl": "https://free.mockerapi.com/405"
  }
}
Request:
require 'net/http'
require 'json'

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

puts "Status Code: #{response.code}"  # 405
puts "Response: #{JSON.parse(response.body)}"
Response Body:
{
  "success": false,
  "status": 405,
  "statusText": "Method Not Allowed - The request method is not supported for the requested resource",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/405",
    "fullUrl": "https://free.mockerapi.com/405"
  }
}
Request:
package main

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

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

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

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

    fmt.Printf("Response: %s\n", body)
}
Response Body:
{
  "success": false,
  "status": 405,
  "statusText": "Method Not Allowed - The request method is not supported for the requested resource",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/405",
    "fullUrl": "https://free.mockerapi.com/405"
  }
}
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/405"))
            .GET()
            .build();

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

        System.out.println("Status Code: " + response.statusCode());  // 405
        System.out.println("Response: " + response.body());
    }
}
Response Body:
{
  "success": false,
  "status": 405,
  "statusText": "Method Not Allowed - The request method is not supported for the requested resource",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/405",
    "fullUrl": "https://free.mockerapi.com/405"
  }
}
Request:
const https = require('https');

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

  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": 405,
  "statusText": "Method Not Allowed - The request method is not supported for the requested resource",
  "timestamp": "2025-10-08T10:30:45.123Z",
  "request": {
    "method": "GET",
    "url": "/405",
    "fullUrl": "https://free.mockerapi.com/405"
  }
}

What is HTTP 405 Method Not Allowed?

HTTP 405 Method Not Allowed 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 405 Method Not Allowed 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 405 Method Not Allowed 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