Available Managed Transforms
This page lists the available Managed Transforms. They can modify HTTP request headers or response headers.
For more complex and customized header modifications, consider using Snippets.
- 
Enabling a Managed Transform may cause issues in your website. You should test any changes in a staging environment. If you detect any undesired or unexpected behavior, consider disabling the Managed Transform and creating a partial implementation using your own transform rule. 
- 
The names of HTTP headers are case-insensitive. Cloudflare may use a capitalization different from the one presented in this page. Make sure that your origin server can handle HTTP request headers regardless of the exact capitalization of their names. 
Adds HTTP headers with bot-related values to the request sent to the origin server:
- cf-bot-score: Contains the bot score (for example,- 30).
- cf-verified-bot: Contains- trueif the request comes from a verified bot, or- falseotherwise.
- cf-ja3-hash: Contains the JA3 fingerprint.
- cf-ja4: Contains the JA4 fingerprint.
Adds HTTP headers with Mutual TLS (mTLS) client authentication values to the request sent to the origin server:
- cf-cert-revoked: Value from the- cf.tls_client_auth.cert_revokedfield.
- cf-cert-verified: Value from the- cf.tls_client_auth.cert_verifiedfield.
- cf-cert-presented: Value from the- cf.tls_client_auth.cert_presentedfield.
- cf-cert-issuer-dn: Value from the- cf.tls_client_auth.cert_issuer_dnfield.
- cf-cert-subject-dn: Value from the- cf.tls_client_auth.cert_subject_dnfield.
- cf-cert-issuer-dn-rfc2253: Value from the- cf.tls_client_auth.cert_issuer_dn_rfc2253field.
- cf-cert-subject-dn-rfc2253: Value from the- cf.tls_client_auth.cert_subject_dn_rfc2253field.
- cf-cert-issuer-dn-legacy: Value from the- cf.tls_client_auth.cert_issuer_dn_legacyfield.
- cf-cert-subject-dn-legacy: Value from the- cf.tls_client_auth.cert_subject_dn_legacyfield.
- cf-cert-serial: Value from the- cf.tls_client_auth.cert_serialfield.
- cf-cert-issuer-serial: Value from the- cf.tls_client_auth.cert_issuer_serialfield.
- cf-cert-fingerprint-sha256: Value from the- cf.tls_client_auth.cert_fingerprint_sha256field.
- cf-cert-fingerprint-sha1: Value from the- cf.tls_client_auth.cert_fingerprint_sha1field.
- cf-cert-not-before: Value from the- cf.tls_client_auth.cert_not_beforefield.
- cf-cert-not-after: Value from the- cf.tls_client_auth.cert_not_afterfield.
- cf-cert-ski: Value from the- cf.tls_client_auth.cert_skifield.
- cf-cert-issuer-ski: Value from the- cf.tls_client_auth.cert_issuer_skifield.
Adds HTTP headers with location information for the visitor's IP address to the request sent to the origin server:
- cf-ipcity: The visitor's city (value from the- ip.src.cityfield).
- cf-ipcountry: The visitor's country (value from the- ip.src.countryfield).
- cf-ipcontinent: The visitor's continent (value from the- ip.src.continentfield).
- cf-iplongitude: The visitor's longitude (value from the- ip.src.lonfield).
- cf-iplatitude: The visitor's latitude (value from the- ip.src.latfield).
- cf-region: The visitor's region (value from the- ip.src.regionfield).
- cf-region-code: The visitor's region code (value from the- ip.src.region_codefield).
- cf-metro-code: The visitor's metro code (value from the- ip.src.metro_codefield).
- cf-postal-code: The visitor's postal code (value from the- ip.src.postal_codefield).
- cf-timezone: The name of the visitor's timezone (value from the- ip.src.timezone.namefield).
Cloudflare always converts non-ASCII characters to UTF-8 (using hexadecimal character representation) in HTTP request and response header values. This applies to location headers added by the Add visitor location headers managed transform.
For example, the header value São Paulo would be encoded as S\u00c3\u00a3o Paulo.
Adds a true-client-ip request header with the visitor's IP address.
This Managed Transform is unavailable when Remove visitor IP headers is enabled.
Removes HTTP headers that may contain the visitor's IP address from the request sent to the origin server. Handles the following HTTP request headers:
- cf-connecting-ip
- x-forwarded-for(refer to the notes below)
- true-client-ip
This Managed Transform is unavailable when Add "True-Client-IP" header is enabled.
For the x-forwarded-for HTTP request header, enabling Remove visitor IP headers will only remove the visitor IP from the header value when Cloudflare receives a request proxied by at least another CDN (content delivery network). In this case, Cloudflare will only keep the IP address of the last proxy.
For example, consider an incoming request proxied by two CDNs (CDN_1 and CDN_2) before reaching the Cloudflare network. The x-forwarded-for header would be similar to the following:
x-forwarded-for: <VISITOR_IP>, <THIRD_PARTY_CDN_1_IP>, <THIRD_PARTY_CDN_2_IP>
With Remove visitor IP headers enabled, the x-forwarded-for header sent to the origin server will be:
x-forwarded-for: <THIRD_PARTY_CDN_2_IP>
Adds an Exposed-Credential-Check request header whenever the WAF detects leaked credentials in the incoming request.
The header can have these values:
| Header + Value | Description | Availability | 
|---|---|---|
| Exposed-Credential-Check: 1 | Previously leaked username and password detected | Pro plan and above | 
| Exposed-Credential-Check: 2 | Previously leaked username detected | Enterprise plan | 
| Exposed-Credential-Check: 3 | Similar combination of previously leaked username and password detected | Enterprise plan | 
| Exposed-Credential-Check: 4 | Previously leaked password detected | All plans | 
You will only receive this managed header at your origin server if:
- The leaked credentials detection in the WAF is turned on.
- The Add Leaked Credentials Checks Header managed transform is turned on.
- Your Cloudflare plan supports the type of credentials detection. For example, Free plans can only know if a password was previously leaked. In this situation, Cloudflare will add an Exposed-Credential-Check: 4header to the request.
Adds a Malicious-Uploads-Detection request header indicating the outcome of scanning uploaded content for malicious signatures.
The header can have one of the following values:
| Header + Value | Description | 
|---|---|
| Malicious-Uploads-Detection: 1 | The request contains at least one malicious content object ( cf.waf.content_scan.has_malicious_objistrue). | 
| Malicious-Uploads-Detection: 2 | The file scanner was unable to scan all the content objects detected in the request ( cf.waf.content_scan.has_failedistrue). | 
| Malicious-Uploads-Detection: 3 | The request contains at least one content object ( cf.waf.content_scan.has_objistrue). | 
For more information, refer to Malicious uploads detection.
Removes the X-Powered-By HTTP response header that provides information about the application at the origin server that handled the request.
Adds several security-related HTTP response headers. The added response headers and values are the following:
- x-content-type-options: nosniff
- x-xss-protection: 1; mode=block
- x-frame-options: SAMEORIGIN
- referrer-policy: same-origin
- expect-ct: max-age=86400, enforce
To increase protection, enable HTTP Strict Transport Security (HSTS) for your website.
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
-