Vue 跨域请求的解决办法

本文介绍如何通过配置代理来解决前端开发中的跨域问题。具体步骤是在项目的config目录下的index.js文件中设置proxyTable的值,将目标API地址指向本地开发服务器,同时通过pathRewrite重写路径。

在 config 目录的 index.js 文件中 设置 proxyTable 的值,样式如下

proxyTable: {
  '/api':{
    target:'http://10.144.26.240:9300',
    changeOrigin:true,
    pathRewrite: {
      '^/api': ''
    }
  }
}
然后再进行请求就OK了

methods: {
  reverseMessage: function() {
    this.$http.get(this.apiUrl)
      .then((response) => {
        console.log(response)
        this.msg = 'success'
      })
      .catch(function(response) {
        console.log(response)
        this.msg = response
      })
  }
}

### 通过 JavaScript 解决 Vue 中的请求问题 在 Vue 项目中进行请求时,通常有以下几种方式可以解决问题: #### 1. 使用 `proxy` 代理配置 在开发环境中,可以通过配置 `vue.config.js` 文件中的 `devServer.proxy` 实现请求代理,从而绕过浏览器的同源策略限制。该方式适用于开发阶段,不适用于生产环境。 ```javascript // vue.config.js module.exports = { devServer: { proxy: { '/api': { target: 'http://localhost:9999', // 后端服务地址 changeOrigin: true, pathRewrite: { '^/api': '' } } } } } ``` 该配置会将所有以 `/api` 开头的请求代理到 `http://localhost:9999`,从而避免问题 [^4]。 #### 2. 封装 `axios` 并设置请求头 在 Vue 项目中,通常使用 `axios` 进行 HTTP 请求,并可以在请求拦截器中统一设置请求头,如 `Content-Type`,以确保请求符合后端接口要求。 ```javascript // request.js import axios from 'axios'; const request = axios.create({ baseURL: '/api', // 开发环境使用代理路径 timeout: 5000 }); request.interceptors.request.use(config => { config.headers['Content-Type'] = 'application/json;charset=utf-8'; return config; }, error => { return Promise.reject(error); }); request.interceptors.response.use(response => { const res = response.data; return res; }, error => { console.error('请求失败:', error); return Promise.reject(error); }); export default request; ``` 该封装方式结合 `proxy` 配置,可以在开发阶段有效处理请求问题 [^3]。 #### 3. 后端配置 CORS 在生产环境中,问题通常由后端配置 CORS 解决。例如在 Express 中,可以通过设置响应头或使用 `cors` 中间件实现支持: ```javascript const express = require('express'); const cors = require('cors'); const app = express(); app.use(cors({ origin: 'http://localhost:8080', // 允许的源 methods: ['GET', 'POST'], allowedHeaders: ['Content-Type', 'Authorization'], credentials: true })); app.get('/api/data', (req, res) => { res.json({ message: 'CORS enabled' }); }); app.listen(3000, () => { console.log('Server running on port 3000'); }); ``` 该配置允许来自 `http://localhost:8080` 的请求,并支持携带凭证 [^2]。 #### 4. 使用 JSONP(适用于 GET 请求) JSONP 是一种传统的解决方案,适用于只支持 GET 请求的场景。其原理是通过 `<script>` 标签的特性加载数据。 ```javascript function handleResponse(data) { console.log('Received data:', data); } const script = document.createElement('script'); script.src = 'http://api.example.com/data?callback=handleResponse'; document.body.appendChild(script); ``` 该方式不适用于现代 Vue 项目,且存在安全限制,仅适用于 GET 请求 [^1]。 #### 5. 使用 Nginx 反向代理 在生产环境中,推荐使用 Nginx 进行反向代理,将前端请求转发到后端服务,从而避免问题: ```nginx server { listen 80; server_name yourdomain.com; location /api { proxy_pass http://localhost:9999; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } location / { root /path/to/your/vue/dist; index index.html; try_files $uri $uri/ =404; } } ``` 此配置将所有 `/api` 请求代理到后端服务,前端访问 `/api/xxx` 时不会触发限制 。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值