Configure mTLS
When you specify API hosts in mTLS authentication, Cloudflare will block all requests that do not have a client certificate for mTLS authentication.
Before you can protect your API or web application with mTLS rules, you need to:
- Check that the certificate installed on your origin server matches the hostname of the client certificate, for example api.example.com. Origin server wildcard certificates such as*.example.comare not supported.
- Create a client certificate.
- Configure your mobile app or IoT device to use your Cloudflare-issued client certificate.
- Enable mutual Transport Layer Security (mTLS) for a host in your zone.
- 
In the Cloudflare dashboard, go to Client Certificates page. Go to Client Certificates
- 
Select Create a mTLS rule. 
- 
In Custom rules, several rule parameters have already been filled in. Enter the URI path you want to protect in Value. 
- 
(Optional) Add a Hostnamefield and enter the mTLS-enabled hostnames you wish to protect in Value.
- 
In Choose action, select Block.
- 
Select Deploy to make the rule active. 
Once you have deployed your mTLS rule, any requests without a valid client certificate will be blocked.
To review your mTLS rule in the Expression Builder, select the wrench icon associated with your rule.
In the Expression Preview, your mTLS rule includes a compound expression formed from two simple expressions joined by the and operator.
The first expression — not cf.tls_client_auth.cert_verified — returns true when a request to access your API or web application does not present a valid client certificate.
The second expression uses the http.request.uri.path field, combined with the in operator, to capture the URI paths your mTLS rule applies to.
Because the action for your rule is Block, only requests that present a valid client certificate can access the specified hosts.
For enhanced security, Cloudflare recommends that you validate the issuer Subject Key Identifier (SKI) hash alongside the verified certificate field. This ensures that only requests presenting a valid client certificate with a specific issuer are allowed.
You can implement this by using an expression similar to the following:
not (cf.tls_client_auth.cert_verified and cf.tls_client_auth.cert_issuer_ski eq "A5AC554235DBA6D963B9CDE0185CFAD6E3F55E9F")To obtain the issuer Subject Key Identifier (SKI) hash of a client certificate stored in the mtls.crt file, you can run the following OpenSSL command:
openssl x509 -noout -ext authorityKeyIdentifier -in mtls.crt | tail -n1 | tr -d ': 'A5AC554235DBA6D963B9CDE0185CFAD6E3F55E9FTo check for revoked client certificates, you can either add a new mTLS rule or add a new expression to the default rule. To check for revoked certificates, you must use the Expression Builder.
When a request includes a revoked certificate, the cf.tls_client_auth.cert_revoked field is set to true. If you combined this with the default mTLS rule, it would look similar to the following:
((not cf.tls_client_auth.cert_verified or cf.tls_client_auth.cert_revoked) and http.request.uri.path in {"/admin"})Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- 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
-