Environment variables
Environment variables are a type of binding that allow you to attach text strings or JSON values to your Worker. Environment variables are available on the env parameter passed to your Worker's fetch event handler.
Text strings and JSON values are not encrypted and are useful for storing application configuration.
Text and JSON values are defined via the [vars] configuration in your Wrangler file. In the following example, API_HOST and API_ACCOUNT_ID are text values and SERVICE_X_DATA is a JSON value.
{  "name": "my-worker-dev",  "vars": {    "API_HOST": "example.com",    "API_ACCOUNT_ID": "example_user",    "SERVICE_X_DATA": {      "URL": "service-x-api.dev.example",      "MY_ID": 123    }  }}name = "my-worker-dev"
[vars]API_HOST = "example.com"API_ACCOUNT_ID = "example_user"SERVICE_X_DATA = { URL = "service-x-api.dev.example", MY_ID = 123 }Refer to the following example on how to access the API_HOST environment variable in your Worker code:
export default {  async fetch(request, env, ctx) {    return new Response(`API host: ${env.API_HOST}`);  },};export interface Env {  API_HOST: string;}
export default {  async fetch(request, env, ctx): Promise<Response> {    return new Response(`API host: ${env.API_HOST}`);  },} satisfies ExportedHandler<Env>;Environments in Wrangler let you specify different configurations for the same Worker, including different values for vars in each environment.
As vars is a non-inheritable key, they are not inherited by environments and must be specified for each environment.
The example below sets up two environments, staging and production, with different values for API_HOST.
{  "name": "my-worker-dev",  "vars": {    "API_HOST": "api.example.com"  },  "env": {    "staging": {      "vars": {        "API_HOST": "staging.example.com"      }    },    "production": {      "vars": {        "API_HOST": "production.example.com"      }    }  }}name = "my-worker-dev"
# top level environment[vars]API_HOST = "api.example.com"
[env.staging.vars]API_HOST = "staging.example.com"
[env.production.vars]API_HOST = "production.example.com"To run Wrangler commands in specific environments, you can pass in the --env or -e flag. For example, you can develop the Worker in an environment called staging by running npx wrangler dev --env staging, and deploy it with npx wrangler deploy --env staging.
Learn about environments in Wrangler.
To add environment variables via the dashboard:
- Log in to Cloudflare dashboard ↗ and select your account.
- Select Workers & Pages.
- In Overview, select your Worker.
- Select Settings.
- Under Variables and Secrets, select Add.
- Select a Type, input a Variable name, and input its Value. This variable will be made available to your Worker.
- (Optional) To add multiple environment variables, select Add variable.
- Select Deploy to implement your changes.
Secrets are environment variables. The difference is secret values are not visible within Wrangler or Cloudflare dashboard after you define them. This means that sensitive data, including passwords or API tokens, should always be encrypted to prevent data leaks. To your Worker, there is no difference between an environment variable and a secret. The secret's value is passed through as defined.
When developing your Worker or Pages Function, create a .dev.vars file in the root of your project to define secrets that will be used when running wrangler dev or wrangler pages dev, as opposed to using environment variables in the Wrangler configuration file. This works both in local and remote development modes.
The .dev.vars file should be formatted like a dotenv file, such as KEY="VALUE":
SECRET_KEY="value"API_TOKEN="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9"To set different secrets for each environment, create files named .dev.vars.<environment-name>. When you use wrangler <command> --env <environment-name>, the corresponding environment-specific file will be loaded instead of the .dev.vars file.
Like other environment variables, secrets are non-inheritable and must be defined per environment.
- Migrating environment variables from Service Worker format to ES modules syntax.
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