HTTP
HTTP validation involves adding a DCV token to your customer's origin.
If your custom hostname does not include a wildcard, Cloudflare will always and automatically attempt to complete DCV through HTTP validation, even if you have selected TXT for your validation method.
This HTTP validation should succeed as long as your customer is pointing to your custom hostname and they do not have any CAA records blocking your chosen certificate authority.
HTTP DCV validation is not allowed for wildcard certificates. You must use TXT validation instead.
If you value simplicity and your customers can handle a few minutes of downtime, you can rely on Cloudflare automatic HTTP validation.
Once you create a new hostname and choose the http
validation method, all your customers have to do is add a CNAME to your $CNAME_TARGET
and Cloudflare will take care of the rest.
What happens after you create the custom hostname
Cloudflare contacts one of our Certificate Authority providers and asks them to issue certificates for the specified hostname. The CA will then inform Cloudflare that we need to “demonstrate control” of this hostname by returning a $DCV_TOKEN
at a specified $DCV_FILENAME
; both the token and the filename are randomly generated by the CA and not known to Cloudflare ahead of time.
For example, if you create a new custom hostname for site.example.com
, the CA might ask us to return the value ca3-38734555d85e4421beb4a3e6d1645fe6
for a request to http://site.example.com/.well-known/pki-validation/ca3-39f423f095be4983922ca0365308612d.txt"
. As soon as we receive that value from the CA we make it accessible at our edge and ask the CA to confirm it’s there so that they can complete validation and the certificate order.
If you would like to complete the issuance process before asking your customer to update their CNAME (or before changing the resolution of your target CNAME to be proxied by Cloudflare), choose another validation method.
Once you create a new hostname and choose this validation method, you will see the following values after a few seconds:
- API: Within the
ssl
object, store the values present in thevalidation_records
array (specificallyhttp_url
andhttp_body
). - Dashboard: When viewing an individual certificate at SSL/TLS > Custom Hostnames, refer to the values for Certificate validation request and Certificate validation response.
At your origin, make the http_body
available in a TXT record at the path specified in http_url
. This path should also be publicly accessible to anyone on the Internet so your CA can access it.
Here is an example NGINX configuration that would return a token:
Once your configuration is live, test that the DCV text file is in place with curl
:
The token is valid for one check cycle. On the next check cycle, Cloudflare will ask the CA to recheck the URL, complete validation, and issue the certificate.
If you would like to request an immediate recheck, rather than wait for the next retry, send a PATCH request with the same values as your initial POST
request.