Create custom errors via API
To configure custom errors via API:
- (Optional) Create a custom error asset based on a URL you provide.
- Create a custom error rule in the http_custom_errorsphase, using the Rulesets API.
The following sections provide examples of common API calls for managing custom error assets at the zone level.
To perform the same operations at the account level, use the corresponding account-level API endpoints.
The following POST request creates new a custom error asset in a zone based on the provided URL:
curl "https://api.cloudflare.com/client/v4/zones/{zone_id}/custom_pages/assets" \--header "Authorization: Bearer <API_TOKEN>" \--header "Content-Type: application/json" \--data '{  "name": "500_error_template",  "description": "Standard 5xx error template page",  "url": "https://example.com/errors/500_template.html"}'{  "result": {    "name": "500_error_template",    "description": "Standard 5xx error template page",    "url": "https://example.com/errors/500_template.html",    "last_updated": "2025-02-10T11:36:07.810215Z",    "size_bytes": 2048  },  "success": true}To create an asset at the account level, use the account-level endpoint:
https://api.cloudflare.com/client/v4/accounts/{account_id}/custom_pages/assetsThe following GET request retrieves a list of custom error assets configured in the zone:
curl "https://api.cloudflare.com/client/v4/zones/{zone_id}/custom_pages/assets" \--header "Authorization: Bearer <API_TOKEN>"{  "result": [    {      "name": "500_error_template",      "description": "Standard 5xx error template page",      "url": "https://example.com/errors/500_template.html",      "last_updated": "2025-02-10T11:36:07.810215Z",      "size_bytes": 2048    }    // ...  ],  "success": true,  "errors": [],  "messages": [],  "result_info": {    "count": 2,    "page": 1,    "per_page": 20,    "total_count": 2,    "total_pages": 1  }}To retrieve a list of assets at the account level, use the account-level endpoint:
https://api.cloudflare.com/client/v4/accounts/{account_id}/custom_pages/assetsThe following PUT request updates the URL of an existing custom error asset at the zone level named 500_error_template:
curl --request PUT \"https://api.cloudflare.com/client/v4/zones/{zone_id}/custom_pages/assets/500_error_template" \--header "Authorization: Bearer <API_TOKEN>" \--header "Content-Type: application/json" \--data '{  "description": "Standard 5xx error template page",  "url": "https://example.com/errors/500_new_template.html"}'{  "result": {    "name": "500_error_template",    "description": "Standard 5xx error template page",    "url": "https://example.com/errors/500_new_template.html",    "last_updated": "2025-02-10T13:13:07.810215Z",    "size_bytes": 3145  },  "success": true}You can update the asset description and URL. You cannot update the asset name after creation.
If you provide the same URL when updating an asset, Cloudflare will fetch the URL again, along with its resources.
To update an asset at the account level, use the account-level endpoint:
https://api.cloudflare.com/client/v4/accounts/{account_id}/custom_pages/assets/{asset_name}The following GET request retrieves the details of an existing custom error asset at the zone level named 500_error_template:
curl "https://api.cloudflare.com/client/v4/zones/{zone_id}/custom_pages/assets/500_error_template" \--header "Authorization: Bearer <API_TOKEN>"{  "result": {    "name": "500_error_template",    "description": "Standard 5xx error template page",    "url": "https://example.com/errors/500_new_template.html",    "last_updated": "2025-02-10T13:13:07.810215Z",    "size_bytes": 3145  },  "success": true}To retrieve an asset at the account level, use the account-level endpoint:
https://api.cloudflare.com/client/v4/accounts/{account_id}/custom_pages/assets/{asset_name}The following DELETE request deletes an existing custom error asset at the zone level named 500_error_template:
curl --request DELETE \"https://api.cloudflare.com/client/v4/zones/{zone_id}/custom_pages/assets/500_error_template" \--header "Authorization: Bearer <API_TOKEN>"If the request is successful, the response will have a 204 HTTP status code.
To delete an asset at the account level, use the account-level endpoint:
https://api.cloudflare.com/client/v4/accounts/{account_id}/custom_pages/assets/{asset_name}When creating a custom error rule via API, make sure you:
- Set the rule action to serve_error.
- Define the rule parameters in the action_parametersfield according to response type.
- Deploy the rule to the http_custom_errorsphase.
The first rule in the http_custom_errors phase ruleset that matches will be applied. No other rules in the ruleset will be matched or applied. Additionally, custom error rules defined at the zone level will have priority over rules defined at the account level.
The provided examples use the following fields in their rule expressions:
- 
http.response.code: Represents the HTTP status code returned to the client, either set by a Cloudflare product or returned by the origin server. Use this field to customize the response for error codes returned by the origin server or by a Cloudflare product such as a Worker.
- 
cf.response.1xxx_code: Contains the specific error code for Cloudflare-generated errors. This field will only work for Cloudflare-generated errors such as 52X and 1XXX.
Follow this workflow to create a custom error rule for a given zone via API:
- 
Use the List zone rulesets operation to check if there is already a ruleset for the http_custom_errorsphase at the zone level.
- 
If the phase ruleset does not exist, create it using the Update a zone entry point ruleset operation, which allows you to create a ruleset if it does not exist and update all the rules in the ruleset. Create the ruleset in the http_custom_errorsphase.If the phase ruleset already exists, use the Update a zone entry point ruleset operation to replace all the rules in the ruleset, or the Add rule to ruleset operation to add a rule to the existing rules in the ruleset. 
To create a custom error rule at the account level, use the corresponding account-level API endpoints.
This example configures a custom JSON error response for all 5XX errors (500-599) in the zone with ID $ZONE_ID. The HTTP status code of the custom error response will be set to 530.
Required API token permissions
 
At least one of the following token permissions 
is required:
- Response Compression Write
- Config Settings Write
- Dynamic URL Redirects Write
- Cache Settings Write
- Custom Errors Write
- Origin Write
- Managed headers Write
- Zone Transform Rules Write
- Mass URL Redirects Write
- Magic Firewall Write
- L4 DDoS Managed Ruleset Write
- HTTP DDoS Managed Ruleset Write
- Sanitize Write
- Transform Rules Write
- Select Configuration Write
- Bot Management Write
- Zone WAF Write
- Account WAF Write
- Account Rulesets Write
- Logs Write
- Logs Write
curl "https://api.cloudflare.com/client/v4/zones/$ZONE_ID/rulesets/phases/http_custom_errors/entrypoint" \  --request PUT \  --header "Authorization: Bearer $CLOUDFLARE_API_TOKEN" \  --json '{    "rules": [        {            "action": "serve_error",            "action_parameters": {                "content": "{\"message\": \"A server error occurred.\"}",                "content_type": "application/json",                "status_code": 530            },            "expression": "http.response.code ge 500 and http.response.code lt 600",            "enabled": true        }    ]  }'This PUT request, corresponding to the Update a zone entry point ruleset operation, replaces any existing rules in the http_custom_errors phase entry point ruleset.
This example configures a custom HTML error response for responses with a 500 HTTP status code, and redefines the response status code to 503.
Required API token permissions
 
At least one of the following token permissions 
is required:
- Response Compression Write
- Config Settings Write
- Dynamic URL Redirects Write
- Cache Settings Write
- Custom Errors Write
- Origin Write
- Managed headers Write
- Zone Transform Rules Write
- Mass URL Redirects Write
- Magic Firewall Write
- L4 DDoS Managed Ruleset Write
- HTTP DDoS Managed Ruleset Write
- Sanitize Write
- Transform Rules Write
- Select Configuration Write
- Bot Management Write
- Zone WAF Write
- Account WAF Write
- Account Rulesets Write
- Logs Write
- Logs Write
curl "https://api.cloudflare.com/client/v4/zones/$ZONE_ID/rulesets/phases/http_custom_errors/entrypoint" \  --request PUT \  --header "Authorization: Bearer $CLOUDFLARE_API_TOKEN" \  --json '{    "rules": [        {            "action": "serve_error",            "action_parameters": {                "content": "<!DOCTYPE html><html><head><meta charset=\"utf-8\"><title>Application unavailable</title></head><body><h1>Application temporarily unavailable</h1><p>Please try again later.</p></body></html>",                "content_type": "text/html",                "status_code": 503            },            "expression": "http.response.code eq 500",            "enabled": true        }    ]  }'This PUT request, corresponding to the Update a zone entry point ruleset operation, replaces any existing rules in the http_custom_errors phase entry point ruleset.
This example configures a custom HTML error response for Cloudflare error 1020 (Access Denied).
Required API token permissions
 
At least one of the following token permissions 
is required:
- Response Compression Write
- Config Settings Write
- Dynamic URL Redirects Write
- Cache Settings Write
- Custom Errors Write
- Origin Write
- Managed headers Write
- Zone Transform Rules Write
- Mass URL Redirects Write
- Magic Firewall Write
- L4 DDoS Managed Ruleset Write
- HTTP DDoS Managed Ruleset Write
- Sanitize Write
- Transform Rules Write
- Select Configuration Write
- Bot Management Write
- Zone WAF Write
- Account WAF Write
- Account Rulesets Write
- Logs Write
- Logs Write
curl "https://api.cloudflare.com/client/v4/zones/$ZONE_ID/rulesets/phases/http_custom_errors/entrypoint" \  --request PUT \  --header "Authorization: Bearer $CLOUDFLARE_API_TOKEN" \  --json '{    "rules": [        {            "action": "serve_error",            "action_parameters": {                "content": "<!DOCTYPE html><html><head><meta charset=\"utf-8\"><title>Access denied</title></head><body><h1>You do not have access to this page</h1><p>Contact us if you think this is an error.</p></body></html>",                "content_type": "text/html"            },            "expression": "cf.response.1xxx_code eq 1020",            "enabled": true        }    ]  }'This PUT request, corresponding to the Update a zone entry point ruleset operation, replaces any existing rules in the http_custom_errors phase entry point ruleset.
This example configures a custom error rule returning a previously created custom error asset named 500_error_template for responses with a 500 HTTP status code.
Required API token permissions
 
At least one of the following token permissions 
is required:
- Response Compression Write
- Config Settings Write
- Dynamic URL Redirects Write
- Cache Settings Write
- Custom Errors Write
- Origin Write
- Managed headers Write
- Zone Transform Rules Write
- Mass URL Redirects Write
- Magic Firewall Write
- L4 DDoS Managed Ruleset Write
- HTTP DDoS Managed Ruleset Write
- Sanitize Write
- Transform Rules Write
- Select Configuration Write
- Bot Management Write
- Zone WAF Write
- Account WAF Write
- Account Rulesets Write
- Logs Write
- Logs Write
curl "https://api.cloudflare.com/client/v4/zones/$ZONE_ID/rulesets/phases/http_custom_errors/entrypoint" \  --request PUT \  --header "Authorization: Bearer $CLOUDFLARE_API_TOKEN" \  --json '{    "rules": [        {            "action": "serve_error",            "action_parameters": {                "asset_name": "500_error_template",                "content_type": "text/html"            },            "expression": "http.response.code eq 500",            "enabled": true        }    ]  }'This PUT request, corresponding to the Update a zone entry point ruleset operation, replaces any existing rules in the http_custom_errors phase entry point ruleset.
The API token used in API requests to manage Custom Error Responses must have at least the following permission:
- Custom Error Rules > Edit
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark