How to Configure Cors on Nginx?

12 minutes read

To configure CORS (Cross-Origin Resource Sharing) on Nginx, you can follow these steps:

  1. Open the Nginx configuration file using a text editor. This file is typically located in the /etc/nginx directory and is named nginx.conf.
  2. Within the http block, add the following code snippet to enable CORS:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
http {
  ...
  
  # CORS configuration
  location / {
    if ($request_method = 'OPTIONS') {
      add_header 'Access-Control-Allow-Origin' '*';
      add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
      add_header 'Access-Control-Allow-Credentials' 'true';
      add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
      add_header 'Access-Control-Max-Age' 1728000;
      add_header 'Content-Type' 'text/plain charset=UTF-8';
      add_header 'Content-Length' 0;
      return 204;
    }
  
    if ($request_method = 'POST') {
      add_header 'Access-Control-Allow-Origin' '*';
      add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
      add_header 'Access-Control-Allow-Credentials' 'true';
      add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
      add_header 'Content-Type' 'text/plain charset=UTF-8';
    }
  
    if ($request_method = 'GET') {
      add_header 'Access-Control-Allow-Origin' '*';
      add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
      add_header 'Access-Control-Allow-Credentials' 'true';
      add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
    }
  }
  
  ...
}


  1. Save the changes made to the configuration file.
  2. Restart the Nginx server for the changes to take effect. This can usually be done by running the command sudo service nginx restart or sudo systemctl restart nginx.


With these configurations in place, Nginx will add the necessary response headers to allow cross-origin requests from any domain (*). You can customize the Access-Control-Allow-Origin header value if you want to restrict access to specific domains instead of allowing all.

Best Nginx Books to Read in January 2025

1
NGINX Cookbook: Over 70 recipes for real-world configuration, deployment, and performance

Rating is 5 out of 5

NGINX Cookbook: Over 70 recipes for real-world configuration, deployment, and performance

2
Nginx HTTP Server: Harness the power of Nginx to make the most of your infrastructure and serve pages faster than ever before, 4th Edition

Rating is 4.9 out of 5

Nginx HTTP Server: Harness the power of Nginx to make the most of your infrastructure and serve pages faster than ever before, 4th Edition

3
NGINX Unit Cookbook: Recipes for Using a Versatile Open Source Server

Rating is 4.8 out of 5

NGINX Unit Cookbook: Recipes for Using a Versatile Open Source Server

4
NGINX Cookbook: Advanced Recipes for High-Performance Load Balancing

Rating is 4.7 out of 5

NGINX Cookbook: Advanced Recipes for High-Performance Load Balancing

5
Nginx Troubleshooting

Rating is 4.6 out of 5

Nginx Troubleshooting

6
Nginx HTTP Server - Third Edition

Rating is 4.5 out of 5

Nginx HTTP Server - Third Edition

7
Nginx Simplified: Practical Guide to Web Server Configuration and Optimization

Rating is 4.4 out of 5

Nginx Simplified: Practical Guide to Web Server Configuration and Optimization

8
Mastering NGINX - Second Edition

Rating is 4.3 out of 5

Mastering NGINX - Second Edition


Can you provide an example of an Nginx configuration block to enable CORS?

Certainly! Here is an example of an Nginx configuration block that enables Cross-Origin Resource Sharing (CORS):

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
location / {
    # CORS configuration
    if ($request_method = 'OPTIONS') {
        add_header 'Access-Control-Allow-Origin' '*';
        add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
        add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization';
        add_header 'Access-Control-Max-Age' 1728000;

        add_header 'Content-Type' 'text/plain charset=UTF-8';
        add_header 'Content-Length' 0;
        return 204;
    }
    if ($request_method = 'POST') {
        add_header 'Access-Control-Allow-Origin' '*';
        add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
        add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization';
    }
    if ($request_method = 'GET') {
        add_header 'Access-Control-Allow-Origin' '*';
        add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
        add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization';
    }
}


In this configuration, the Access-Control-Allow-Origin header is set to * to allow requests from any origin. The Access-Control-Allow-Methods header specifies the allowed HTTP methods (GET, POST, OPTIONS) for cross-origin requests. The Access-Control-Allow-Headers header mentions the allowed request headers. The Access-Control-Max-Age header sets the caching time for the preflight response.


Note: CORS configuration can vary depending on your specific requirements. You may need to modify the example above to match your desired settings or add more specific rules.


What is the default location of the Nginx configuration file?

The default location of the Nginx configuration file depends on the operating system and the method of installation. However, some common default locations include:

  • Ubuntu/Debian: /etc/nginx/nginx.conf
  • CentOS/RHEL: /etc/nginx/nginx.conf
  • Mac: /usr/local/etc/nginx/nginx.conf
  • Windows: C:\nginx\conf\nginx.conf


Please note that these are default locations and may vary depending on the specific installation or customization.


How do you allow multiple origins in the CORS configuration?

To allow multiple origins in the CORS (Cross-Origin Resource Sharing) configuration, you need to specify each origin separately. Here's an example of how you can do it:

  1. In your server-side code or server configuration file, identify where the CORS configuration is defined. It may vary depending on the language or framework you are using.
  2. Within the CORS configuration, locate the "allowed origins" or "allowed origin" property. This property determines which origins are allowed to access your server resources.
  3. Modify the "allowed origins" property to include the origins you want to allow. You can add multiple origins by separating them with commas.


Example using Express.js framework in Node.js:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
const express = require('express');
const app = express();

// CORS configuration
const allowedOrigins = ['http://example.com', 'https://example.net'];

app.use((req, res, next) => {
  const origin = req.headers.origin;
  if (allowedOrigins.includes(origin)) {
    res.setHeader('Access-Control-Allow-Origin', origin);
  }
  // Other CORS headers...
  next();
});

// Other server configurations and routing...

app.listen(3000, () => {
  console.log('Server listening on port 3000');
});


In this example, requests from 'http://example.com' and 'https://example.net' origins are allowed by setting the 'Access-Control-Allow-Origin' header. Other origins will be blocked.


Remember to replace 'http://example.com' and 'https://example.net' with the actual origins you want to allow.


Note: Be cautious when allowing multiple origins as it can potentially increase the security risks. Only allow the origins that are necessary for your application and take appropriate security measures to protect against cross-origin attacks.

Best Web Hosting Providers in 2025

1
AWS

Rating is 5 out of 5

AWS

2
DigitalOcean

Rating is 4.9 out of 5

DigitalOcean

3
Vultr

Rating is 4.8 out of 5

Vultr

4
Cloudways

Rating is 4.7 out of 5

Cloudways


Is there a way to disable CORS temporarily for troubleshooting purposes?

Yes, there are several ways to temporarily disable the Cross-Origin Resource Sharing (CORS) policy for troubleshooting purposes. Here are a few options:

  1. Use a CORS browser extension: There are various browser extensions available that allow you to toggle CORS on and off for specific websites. Examples include "CORS Everywhere" for Firefox and "Allow CORS: Access-Control-Allow-Origin" for Chrome. By installing these extensions, you can easily disable CORS for troubleshooting.
  2. Utilize a CORS proxy: CORS proxy servers act as intermediaries between your browser and the target server, allowing you to bypass CORS restrictions. You can find multiple CORS proxy services available online. Simply configure your API requests to go through the proxy server, and it will handle the CORS-related issues.
  3. Modify the server-side code: If you have access to the server-side code, you can modify it to disable CORS temporarily. This approach involves updating the response headers for the specific API endpoints to allow all origins (("*") or the specific origin you want to access the API from.


It is important to note that while disabling CORS temporarily can be helpful for troubleshooting, it is not recommended for production environments as it weakens the security posture of your application.


What header does Nginx use to handle CORS requests?

Nginx uses the Access-Control-Allow-Origin header to handle CORS (Cross-Origin Resource Sharing) requests.

Facebook Twitter LinkedIn Telegram Whatsapp Pocket

Related Posts:

To configure multiple React projects using Nginx, you can follow these steps:Install Nginx: Start by installing Nginx on your server or local machine. You can refer to the Nginx website for installation instructions specific to your operating system. Configure...
To build a proxy using Nginx, you need to follow these steps:Install Nginx: Start by installing Nginx on your server or local machine. You can download it from the official Nginx website or use package managers like apt or yum. Configure Nginx as a Reverse Pro...
To override the location directive in Nginx, you can modify the Nginx configuration file (usually located at /etc/nginx/nginx.conf, /etc/nginx/conf.d/*.conf, or /etc/nginx/sites-available/*) or create a new custom configuration file in conf.d or sites-availabl...