nodeJs 解决跨域

1. 使用 cors 中间件

cors 是一个 Node.js 的中间件,用于处理跨域请求。首先,需要通过 npm 安装 cors 包:

bash 复制代码
npm install cors

在 nodeJS 使用它

javascript 复制代码
const express = require("express");

const cors = require("cors");



const app = express();



// 全局使用 cors 中间件,允许所有来源的跨域请求

app.use(cors());



app.listen(3000, () => {

  console.log("服务器运行在 3000 端口");

});

如果只想允许特定来源的跨域请求,可以像这样配置:

javascript 复制代码
const corsOptions = {

  origin: "http://example.com", // 只允许来自 http://example.com 的请求

  methods: "GET,HEAD,PUT,PATCH,POST,DELETE",

  allowedHeaders: "Content-Type,Authorization",

};



app.use(cors(corsOptions));

2. 设置响应头

也可以手动设置响应头来解决跨域问题。

javascript 复制代码
const express = require("express");



const app = express();



app.use((req, res, next) => {

  res.header("Access-Control-Allow-Origin", "*"); // 允许任何来源的请求

  res.header("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS"); // 允许的请求方法

  res.header("Access-Control-Allow-Headers", "Content-Type, Authorization"); // 允许的请求头



  if (req.method === "OPTIONS") {

    res.sendStatus(200); // 对预检请求返回 200 状态码

  } else {

    next();

  }

});



app.listen(3000, () => {

  console.log("服务器运行在 3000 端口");

});
相关推荐
轮回的秋11 小时前
nvm 管理多版本node
node.js·nvm
s***558116 小时前
如何自由切换 Node.js 版本?
node.js
数字冰雹1 天前
为城市治理装上“数字引擎”
中间件·数据可视化
喜欢吃豆1 天前
LangChain v1.0 技术研究报告:架构范式向智能体中间件与图运行时的演进
中间件·架构·langchain·大模型
无心水2 天前
【分布式利器:RocketMQ】RocketMQ基本原理详解:架构、流程与核心特性(附实战场景)
中间件·架构·rocketmq·topic·rocketmq基本原理·电商金融mq·nameserver
小小前端_我自坚强2 天前
渐进增强、优雅降级及现代Web开发技术详解
javascript·node.js
b***9102 天前
Node.js卸载超详细步骤(附图文讲解)
node.js
mixboot2 天前
配置 Node.js npm镜像源 安装 Claude Code
npm·node.js·nvm·claude code
q***71012 天前
如何在Windows系统上安装和配置Node.js及Node版本管理器(nvm)
windows·node.js
q***06472 天前
最新最详细的配置Node.js环境教程
node.js