跨域问题如何解决?

✅ 一、后端设置 CORS(最正规、推荐)

这是标准解法,让服务端允许跨域访问。

Node.js(Express)

复制代码
const express = require('express')
const cors = require('cors')

const app = express()
app.use(cors()) // 允许所有跨域

app.get('/api', (req, res) => {
  res.json({ msg: 'ok' })
})

app.listen(3000)

或者手动设置:

复制代码
res.setHeader('Access-Control-Allow-Origin', '*')
res.setHeader('Access-Control-Allow-Methods', 'GET,POST,PUT,DELETE')
res.setHeader('Access-Control-Allow-Headers', 'Content-Type')

✅ 二、前端代理(开发环境最常用)

你做 React / Vue 项目,这个你一定会用到。

👉 Vite

复制代码
// vite.config.js
export default {
  server: {
    proxy: {
      '/api': {
        target: 'http://backend.com',
        changeOrigin: true,
        rewrite: path => path.replace(/^\/api/, '')
      }
    }
  }
}

👉 Vue CLI

复制代码
// vue.config.js
module.exports = {
  devServer: {
    proxy: {
      '/api': {
        target: 'http://backend.com',
        changeOrigin: true
      }
    }
  }
}

👉 React(Create React App)

复制代码
"proxy": "http://backend.com"

👉 原理:

本地 dev server 帮你转发请求 → 浏览器以为是同源


✅ 三、Nginx 反向代理(生产环境常用)

复制代码
server {
  listen 80;

  location /api/ {
    proxy_pass http://backend.com/;
  }
}

👉 前端请求:

复制代码
/api/user

👉 实际转发:

复制代码
http://backend.com/user

✅ 四、JSONP(只支持 GET,基本淘汰)

复制代码
function jsonp(url) {
  const script = document.createElement('script')
  script.src = url
  document.body.appendChild(script)
}

👉 缺点:

  • 只能 GET

  • 安全性差

    👉 现在几乎不用


✅ 五、浏览器插件(仅开发调试)

比如 Chrome 插件关闭 CORS

👉 适合:

  • 本地调试

    👉 不可用于生产


❗ 六、为什么会出现跨域(面试重点)

浏览器会校验:

条件 示例
协议不同 http vs https
域名不同 a.com vs b.com
端口不同 3000 vs 8080

🚨 七、预检请求(OPTIONS)

复杂请求会先发一个:

复制代码
OPTIONS /api

后端必须允许:

复制代码
Access-Control-Allow-Methods
Access-Control-Allow-Headers

🧠 实战建议(结合你项目)

你现在做 React + Vue 项目:

👉 开发环境:

  • proxy(最方便)

👉 生产环境:

  • Nginx 反向代理

  • 后端 CORS

👉 后端可控:

  • 直接开 CORS(最佳)

👍 一句话总结

👉 跨域不是前端 bug,是浏览器安全机制

👉 解决核心:让服务器"允许你访问" 或 "绕过浏览器同源限制"

相关推荐
KevinWang_39 分钟前
AI 基础设施及其应用
前端
AIFarmer40 分钟前
npm : 无法将“npm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确, 然后再试一次。
前端·npm·node.js
小红的布丁44 分钟前
Redis 集群详解:主从哨兵和切片集群有什么区别
前端·数据库·redis
小高0071 小时前
🔥前端性能内卷终点?Signals 正在重塑我们的开发习惯
前端·javascript·vue.js
周末也要写八哥1 小时前
HTML网页设计入门之“做前端”的基本思路
前端·html
VelinX1 小时前
【个人学习||vue】
前端·vue.js·学习
禅思院1 小时前
前端性能优化:从“术“到“道“的完整修炼指南
前端·性能优化·前端性能优化·分层优化模
用泥种荷花2 小时前
OpenClaw 插件开发避坑指南
前端
恋猫de小郭2 小时前
compose_skill 和 android skills,对 Android 项目提升巨大的专家 AI Skills
android·前端·flutter
J_liaty2 小时前
Vue2 从入门到精通
前端·javascript·vue.js