centos

CentOS Node.js 配置跨域资源共享(CORS)

小樊
39
2025-06-18 08:25:23
栏目: 编程语言

在 CentOS 系统上配置 Node.js 应用以支持跨域资源共享(CORS),可以通过多种方式实现。以下是几种常见的方法:

方法一:使用 Express 框架和 cors 中间件

  1. 安装 Node.js 和 npm: 确保你已经在 CentOS 上安装了 Node.js 和 npm。如果没有安装,可以参考以下步骤:

    sudo yum install -y nodejs npm
    
  2. 创建一个新的 Node.js 项目: 创建一个新的目录并进入该目录,然后初始化一个新的 Node.js 项目。

    mkdir my-node-app
    cd my-node-app
    npm init -y
    
  3. 安装 Express 和 cors 中间件: 使用 npm 安装 Express 和 cors 中间件。

    npm install express cors
    
  4. 创建一个简单的 Express 应用: 创建一个 index.js 文件,并添加以下代码:

    const express = require('express');
    const cors = require('cors');
    
    const app = express();
    const port = 3000;
    
    // 使用 cors 中间件
    app.use(cors());
    
    app.get('/', (req, res) => {
      res.send('Hello World!');
    });
    
    app.listen(port, () => {
      console.log(`Server running at http://localhost:${port}/`);
    });
    
  5. 运行应用: 在终端中运行你的应用。

    node index.js
    

    现在,你的应用应该在 http://localhost:3000 上运行,并且支持 CORS。

方法二:手动设置 CORS 头

如果你不想使用中间件,也可以手动设置 CORS 头。以下是一个示例:

const http = require('http');

const server = http.createServer((req, res) => {
  // 设置 CORS 头
  res.setHeader('Access-Control-Allow-Origin', '*');
  res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
  res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization');

  if (req.method === 'OPTIONS') {
    res.writeHead(200);
    return res.end();
  }

  res.end('Hello World!');
});

const port = 3000;
server.listen(port, () => {
  console.log(`Server running at http://localhost:${port}/`);
});

方法三:使用 Nginx 反向代理

如果你希望通过 Nginx 反向代理来处理 CORS,可以按照以下步骤进行配置:

  1. 安装 Nginx: 如果你还没有安装 Nginx,可以使用以下命令安装:

    sudo yum install nginx
    
  2. 配置 Nginx: 编辑 Nginx 配置文件(通常位于 /etc/nginx/nginx.conf/etc/nginx/conf.d/default.conf),添加以下内容:

    server {
        listen 80;
        server_name yourdomain.com;
    
        location / {
            proxy_pass http://localhost:3000;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
    
            add_header 'Access-Control-Allow-Origin' '*' always;
            add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS' always;
            add_header 'Access-Control-Allow-Headers' 'Content-Type, Authorization' always;
    
            if ($request_method = 'OPTIONS') {
                add_header 'Access-Control-Allow-Origin' '*';
                add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS';
                add_header 'Access-Control-Allow-Headers' 'Content-Type, Authorization';
                add_header 'Content-Length' 0;
                add_header 'Content-Type' 'text/plain charset=UTF-8';
                return 200;
            }
        }
    }
    
  3. 重启 Nginx: 保存配置文件并重启 Nginx。

    sudo systemctl restart nginx
    

现在,你的 Node.js 应用应该可以通过 Nginx 反向代理访问,并且支持 CORS。

选择适合你需求的方法进行配置即可。

0
看了该问题的人还看了