vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > Vue解决Ajax跨域问题

Vue解决开发环境Ajax跨域问题的多种方法对比

作者:咖啡の猫

本文将带大家深入理解跨域原理,并提供 Vue CLI(webpack)和 Vite 两种构建工具下的完整解决方案,让大家的开发流程更顺畅,希望对大家有所帮助

一、前言

在 Vue 项目开发中,我们经常会遇到这样的报错:

Access to XMLHttpRequest at 'http://api.example.com/login' 
from origin 'http://localhost:8080' has been blocked by CORS policy: 
No 'Access-Control-Allow-Origin' header is present on the requested resource.

这就是典型的 跨域请求被浏览器拦截

虽然生产环境中通常由后端配置 CORS 或 Nginx 反向代理解决,但在本地开发阶段,前后端往往独立运行(前端 localhost:8080,后端 localhost:3000),如何优雅地绕过跨域限制?

本文将带你深入理解跨域原理,并提供 Vue CLI(webpack)和 Vite 两种构建工具下的完整解决方案,让你的开发流程更顺畅。

二、什么是跨域?为什么会出现?

同源策略(Same-Origin Policy)

浏览器出于安全考虑,实施了“同源策略”:只有 协议(protocol)、域名(host)、端口(port) 完全相同,才允许访问彼此的资源。

当前页面请求地址是否跨域原因
http://localhost:8080http://localhost:8080/api❌ 不跨域同协议、同域名、同端口
http://localhost:8080http://localhost:3000/api✅ 跨域端口不同
http://localhost:8080https://localhost:8080/api✅ 跨域协议不同
http://localhost:8080http://api.dev.com:8080✅ 跨域域名不同

浏览器会阻止 JavaScript 发起跨域请求,除非服务端明确允许(CORS)。

三、开发环境 vs 生产环境的区别

环境特点跨域解决方案
开发环境前后端分离,本地启动使用 开发服务器代理(Proxy)
生产环境部署在同一域名下通过 Nginx 反向代理或后端开启 CORS

重点:本文聚焦 开发环境 的跨域解决!

四、解决方案 1:Vue CLI / webpack-dev-server 代理(推荐)

如果你使用的是 Vue CLI 创建的项目(基于 webpack),可以通过配置 vue.config.js 实现请求代理。

1. 创建vue.config.js

在项目根目录创建文件 vue.config.js

// vue.config.js
const { defineConfig } = require('@vue/cli-service')

module.exports = defineConfig({
  devServer: {
    proxy: {
      '/api': {
        target: 'http://localhost:3000', // 后端服务地址
        changeOrigin: true,               // 修改请求头中的 origin
        secure: false,                    // 支持 https 目标
        pathRewrite: {
          '^/api': ''                     // 重写路径,去掉 /api 前缀
        }
      }
    }
  }
})

2. 前端代码中发起请求

// 原本请求:http://localhost:3000/user/login
// 现在只需请求:/api/user/login

axios.post('/api/user/login', { username, password })
  .then(res => console.log(res.data))

3. 工作原理图解

前端代码 → http://localhost:8080
           ↓ (浏览器)
axios.post('/api/user/login')
           ↓
Vue DevServer 拦截以 /api 开头的请求
           ↓
转发到真实后端 → http://localhost:3000/user/login
           ↓
返回响应 → 再由 DevServer 返回给前端

优点

五、解决方案 2:Vite 项目代理(适用于 Vue 3 + Vite)

如果你使用的是 Vite 构建的 Vue 项目(如 create-vuevite create),配置方式略有不同。

1. 修改vite.config.js

// vite.config.js
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'

export default defineConfig({
  plugins: [vue()],
  server: {
    proxy: {
      '/api': {
        target: 'http://localhost:3000',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, '') // Vite 中用 rewrite
      }
    }
  }
})

注意:Vite 中使用 rewrite 而不是 pathRewrite

2. 前端请求方式不变

axios.get('/api/users') // 自动代理到 http://localhost:3000/users

六、进阶配置:多接口前缀代理

如果项目需要对接多个后端服务,可以配置多个代理规则:

// vue.config.js 或 vite.config.js
proxy: {
  '/api': {
    target: 'http://localhost:3000',
    changeOrigin: true,
    pathRewrite: { '^/api': '' }
  },
  '/upload': {
    target: 'http://upload.service.com',
    changeOrigin: true
  },
  '/mock': {
    target: 'https://mockapi.com',
    changeOrigin: true,
    secure: false
  }
}

示例:

七、其他方案对比(不推荐用于开发)

方案是否推荐说明
JSONP仅支持 GET,已被时代淘汰
CORS 后端配置⚠️ 有条件需后端配合,开发期可能无法修改
浏览器禁用安全策略危险操作,影响系统安全
自己起一个中间 Node 服务⚠️ 复杂小题大做,不如用代理

结论开发服务器代理是最佳选择

八、常见问题与解决方案

问题 1:代理后接口 404?

原因pathRewrite 配置错误,路径未正确转发。

解决

问题 2:WebSocket 也能代理吗?

可以!Vite 和 webpack 都支持 WebSocket 代理:

proxy: {
  '/ws': {
    target: 'ws://localhost:8080',
    ws: true,
    changeOrigin: true
  }
}

问题 3:代理后 Cookie/Sessions 丢失?

原因:跨域时 Cookie 默认不携带。

解决

前端请求设置 withCredentials: true

axios.defaults.withCredentials = true

后端响应头需允许:

Access-Control-Allow-Credentials: true
Access-Control-Allow-Origin: http://localhost:8080  # 不能为 *

九、生产环境部署建议

开发期用代理,上线后怎么办

推荐方案:Nginx 反向代理

server {
    listen 80;
    server_name yourdomain.com;

    # 前端静态资源
    location / {
        root /usr/share/nginx/html;
        try_files $uri $uri/ /index.html;
    }

    # API 代理到后端
    location /api/ {
        proxy_pass http://backend-server:3000/;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }
}

这样前后端共用同一域名,彻底解决跨域问题。

十、总结

工具配置文件核心配置
Vue CLI (webpack)vue.config.jsdevServer.proxy
Vitevite.config.jsserver.proxy
生产环境Nginxlocation + proxy_pass

开发环境跨域三步走

到此这篇关于Vue解决开发环境Ajax跨域问题的多种方法对比的文章就介绍到这了,更多相关Vue解决Ajax跨域问题内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文