Request
The Request interface represents an HTTP request and is part of the Fetch API.
Background
The most common way you will encounter a Request object is as a property of an incoming FetchEvent.
---
highlight: [2]
---
addEventListener("fetch", event => {
  let request = event.request // Request object
  // ...
})
You may also want to construct a Request yourself when you need to modify a request object, because a FetchEvent’s request property is immutable.
addEventListener("fetch", event => {
  const request = event.request
  const url = "https://example.com"
  const modifiedRequest = new Request(url, {
    body: request.body,
    headers: request.headers,
    method: request.method,
    redirect: request.redirect
  })
  // ...
})
The global fetch method itself invokes the Request constructor. The 
    RequestInit
   and 
    RequestInitCfProperties
   types defined below also describe the valid parameters that can be passed to fetch.
Constructor
let request = new Request(input [, init])
Parameters
- 
inputstring | Request- Either a string that contains a URL, or an existing Requestobject.
 
- Either a string that contains a URL, or an existing 
- 
initRequestInit- Optional options object that contains settings to apply to the Request.
 
- Optional options object that contains settings to apply to the 
    
      
    
    RequestInit
  
- 
- Cloudflare-specific properties that can be set on the Requestthat control how Cloudflare’s edge handles the request.
 
- Cloudflare-specific properties that can be set on the 
- 
methodstring- The HTTP request method. The default is GET.
 
- The HTTP request method. The default is 
- 
headersHeaders
- 
bodystring | ReadableStream | FormData | URLSearchParams- The request body, if any.
 
- 
redirectstring- The redirect mode to use: follow,error, ormanual. The default for a newRequestobject isfollow. Note, however, that the incomingRequestproperty of aFetchEventwill have redirect modemanual.
 
- The redirect mode to use: 
    
      
    
    RequestInitCfProperties
  
An object containing Cloudflare-specific properties that can be set on the Request object. For example:
// Disable ScrapeShield for this request.
fetch(event.request, { cf: { scrapeShield: false } })
Invalid or incorrectly-named keys in the cf object will be silently ignored. Consider using TypeScript and 
  @cloudflare/workers-types to ensure proper use of the cf object.
- 
appsboolean- Whether 
  Cloudflare Apps should be enabled for this request. Defaults to true.
 
- Whether 
  Cloudflare Apps should be enabled for this request. Defaults to 
- 
cacheEverythingboolean- This option forces Cloudflare to cache the response for this request, regardless of what headers are seen on the response. This is equivalent to setting the Page Rule 
  Cache Level (to Cache Everything). Defaults to false. This option applies toGETandHEADrequest methods only.
 
- This option forces Cloudflare to cache the response for this request, regardless of what headers are seen on the response. This is equivalent to setting the Page Rule 
  Cache Level (to Cache Everything). Defaults to 
- 
cacheKeystring- A request’s cache key is what determines if two requests are the same for caching purposes. If a request has the same cache key as some previous request, then Cloudflare can serve the same cached response for both.
 
- 
cacheTtlnumber- This option forces Cloudflare to cache the response for this request, regardless of what headers are seen on the response. This is equivalent to setting two Page Rules: 
  Edge Cache TTL and 
  Cache Level (to Cache Everything). The value must be zero or a positive number. A value of 0indicates that the cache asset expires immediately. This option applies toGETandHEADrequest methods only.
 
- This option forces Cloudflare to cache the response for this request, regardless of what headers are seen on the response. This is equivalent to setting two Page Rules: 
  Edge Cache TTL and 
  Cache Level (to Cache Everything). The value must be zero or a positive number. A value of 
- 
cacheTtlByStatus{ [key: string]: number }- This option is a version of the cacheTtlfeature which chooses a TTL based on the response’s status code. If the response to this request has a status code that matches, Cloudflare will cache for the instructed time and override cache instructives sent by the origin. For example:{ "200-299": 86400, 404: 1, "500-599": 0 }. The value can be any integer, including zero and negative integers. A value of0indicates that the cache asset expires immediately. Any negative value instructs Cloudflare not to cache at all. This option applies toGETandHEADrequest methods only.
 
- This option is a version of the 
- 
minify{ javascript?: boolean; css?: boolean; html?: boolean; }- Enables or disables 
  AutoMinify for various file types. For example: { javascript: true, css: true, html: false }.
 
- Enables or disables 
  AutoMinify for various file types. For example: 
- 
mirageboolean- Whether 
  Mirage should be enabled for this request, if otherwise configured for this zone. Defaults to true.
 
- Whether 
  Mirage should be enabled for this request, if otherwise configured for this zone. Defaults to 
- 
polishstring- Sets 
  Polish mode. The possible values are lossy,losslessoroff.
 
- Sets 
  Polish mode. The possible values are 
- 
resolveOverridestring- Directs the request to an alternate origin server by overriding the DNS lookup. The value of resolveOverridespecifies an alternate hostname which will be used when determining the origin IP address, instead of using the hostname specified in the URL. TheHostheader of the request will still match what is in the URL. Thus,resolveOverrideallows a request to be sent to a different server than the URL /Hostheader specifies. However,resolveOverridewill only take effect if both the URL host and the host specified byresolveOverrideare within your zone. If either specifies a host from a different zone / domain, then the option will be ignored for security reasons. If you need to direct a request to a host outside your zone (while keeping theHostheader pointing within your zone), first create a CNAME record within your zone pointing to the outside host, and then setresolveOverrideto point at the CNAME record. Note that, for security reasons, it is not possible to set theHostheader to specify a host outside of your zone unless the request is actually being sent to that host.
 
- Directs the request to an alternate origin server by overriding the DNS lookup. The value of 
- 
scrapeShieldboolean- Whether 
  ScrapeShield should be enabled for this request, if otherwise configured for this zone. Defaults to true.
 
- Whether 
  ScrapeShield should be enabled for this request, if otherwise configured for this zone. Defaults to 
Properties
All properties of an incoming Request object (that is, event.request) are read only. To modify a request, create a new Request object and pass the options to modify to its 
    constructor
  .
- 
bodyReadableStream- Stream of the body contents.
 
- 
bodyUsedBoolean- Declares whether the body has been used in a response yet.
 
- 
cfIncomingRequestCfProperties- An object containing properties about the incoming request provided by Cloudflare’s edge network.
 
- 
headersHeaders
- 
methodstring- Contains the request’s method, for example, GET,POST, etc.
 
- Contains the request’s method, for example, 
- 
redirectstring- The redirect mode to use: follow,error, ormanual. Thefetchmethod will automatically follow redirects if the redirect mode is set tofollow. If set tomanual, the3xxredirect response will be returned to the caller as-is. The default for a newRequestobject isfollow. Note, however, that the incomingRequestproperty of aFetchEventwill have redirect modemanual.
 
- The redirect mode to use: 
- 
urlstring- Contains the URL of the request.
 
    
      
    
    IncomingRequestCfProperties
  
In addition to the properties on the standard 
  Request object, the request.cf object on an inbound Request contains information about the request provided by Cloudflare’s edge.
All plans have access to:
- 
asnstring- ASN of the incoming request, for example, 395747.
 
- ASN of the incoming request, for example, 
- 
asOrganizationstring- The organization which owns the ASN of the incoming request, for example, Google Cloud.
 
- The organization which owns the ASN of the incoming request, for example, 
- 
botManagementObject | null- Only set when using Cloudflare Bot Management. Object with the following properties: score,verifiedBot,staticResource, andja3Hash. Refer to Bot Management Variables for more details.
 
- Only set when using Cloudflare Bot Management. Object with the following properties: 
- 
colostring- The three-letter 
  IATAairport code of the data center that the request hit, for example,"DFW".
 
- The three-letter 
  
- 
countrystring | null- Country of the incoming request. The two-letter country code in the request. This is the same value as that provided in the CF-IPCountryheader, for example,"US".
 
- Country of the incoming request. The two-letter country code in the request. This is the same value as that provided in the 
- 
isEUCountrystring | null- If the country of the incoming request is in the EU, this will return "1". Otherwise, this property will be omitted.
 
- If the country of the incoming request is in the EU, this will return 
- 
httpProtocolstring- HTTP Protocol, for example, "HTTP/2".
 
- HTTP Protocol, for example, 
- 
requestPrioritystring | null- The browser-requested prioritization information in the request object, for example, "weight=192;exclusive=0;group=3;group-weight=127".
 
- The browser-requested prioritization information in the request object, for example, 
- 
tlsCipherstring- The cipher for the connection to Cloudflare, for example, "AEAD-AES128-GCM-SHA256".
 
- The cipher for the connection to Cloudflare, for example, 
- 
tlsClientAuthObject | null- Only set when using Cloudflare Access or API Shield (mTLS). Object with the following properties: certFingerprintSHA1,certFingerprintSHA256,certIssuerDN,certIssuerDNLegacy,certIssuerDNRFC2253,certIssuerSKI,certIssuerSerial,certNotAfter,certNotBefore,certPresented,certRevoked,certSKI,certSerial,certSubjectDN,certSubjectDNLegacy,certSubjectDNRFC2253,certVerified.
 
- Only set when using Cloudflare Access or API Shield (mTLS). Object with the following properties: 
- 
tlsVersionstring- The TLS version of the connection to Cloudflare, for example, TLSv1.3.
 
- The TLS version of the connection to Cloudflare, for example, 
- 
citystring | null- City of the incoming request, for example, "Austin".
 
- City of the incoming request, for example, 
- 
continentstring | null- Continent of the incoming request, for example, "NA".
 
- Continent of the incoming request, for example, 
- 
latitudestring | null- Latitude of the incoming request, for example, "30.27130".
 
- Latitude of the incoming request, for example, 
- 
longitudestring | null- Longitude of the incoming request, for example, "-97.74260".
 
- Longitude of the incoming request, for example, 
- 
postalCodestring | null- Postal code of the incoming request, for example, "78701".
 
- Postal code of the incoming request, for example, 
- 
metroCodestring | null- Metro code (DMA) of the incoming request, for example, "635".
 
- Metro code (DMA) of the incoming request, for example, 
- 
regionstring | null- If known, the 
  ISO 3166-2 name for the first level region associated with the IP address of the incoming request, for example, "Texas".
 
- If known, the 
  ISO 3166-2 name for the first level region associated with the IP address of the incoming request, for example, 
- 
regionCodestring | null- If known, the 
  ISO 3166-2 code for the first-level region associated with the IP address of the incoming request, for example, "TX".
 
- If known, the 
  ISO 3166-2 code for the first-level region associated with the IP address of the incoming request, for example, 
- 
timezonestring- Timezone of the incoming request, for example, "America/Chicago".
 
- Timezone of the incoming request, for example, 
Methods
Instance methods
These methods are only available on an instance of a Request object or through its prototype.
- 
clone()Promise<Request>- Creates a copy of the Requestobject.
 
- Creates a copy of the 
- 
arrayBuffer()Promise<ArrayBuffer>- Returns a promise that resolves with an 
  ArrayBufferrepresentation of the request body.
 
- Returns a promise that resolves with an 
  
- 
formData()Promise<FormData>- Returns a promise that resolves with a 
  FormDatarepresentation of the request body.
 
- Returns a promise that resolves with a 
  
- 
json()Promise<Object>- Returns a promise that resolves with a JSON representation of the request body.
 
- 
text()Promise<string>- Returns a promise that resolves with a string (text) representation of the request body.
 
The request context
The Request context is the context of the "fetch" event callback. It is important to note that due to how Workers are executed, asynchronous tasks (for example, fetch) can only be run inside the request context.
The request context is available inside of the 
    FetchEvent handler
  :
addEventListener("fetch", event => {
  // Request context available here
  event.respondWith(/*...*/)
})
    
      
    
    When passing a promise to fetch event .respondWith()
  
If you pass a Response promise to the fetch event 
    .respondWith()
   method, the request context is active during any asynchronous tasks which run before the Response promise has settled. You can pass the event to an async handler, for example:
addEventListener("fetch", event => {
  event.respondWith(eventHandler(event))
})
// No request context available here
async function eventHandler(event){
  // Request context available here
  return new Response("Hello, Workers!")
}
    
      
    
    Errors when attempting to access an inactive Request context
  
Any attempt to use APIs such as fetch() or access the Request context during script startup will throw an exception:
const promise = fetch("https://example.com/") // Error
async function eventHandler(event){..}
This code snippet will throw during script startup, and the "fetch" event listener will never be registered.