Vue中的跨域解决方案

Vue中的跨域解决方案

什么是跨域?
跨域指浏览器不允许当前页面的所在的源去请求另一个源的数据。源指协议,端口,域名。只要这个3个中有一个不同就是跨域。

# 协议跨域
http://a.baidu.com访问https://a.baidu.com;
# 端口跨域
http://a.baidu.com:8080访问http://a.baidu.com:80;
# 域名跨域
http://a.baidu.com访问http://b.baidu.com;

——————————————————————————————

解决方案

  • 第一种,服务端(后台Java)更改header
res.header("Access-Control-Allow-Origin", "*"); // 允许的域名
res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS"); // 允许的请求方法
  • 第二种:代理
    原因就是因为客户端请求服务端的数据是存在跨域问题的,而服务器和服务器之间可以相互请求数据,是没有跨域的概念(如果服务器没有设置禁止跨域的权限问题),也就是说,我们可以配置一个代理的服务器可以请求另一个服务器中的数据,然后把请求出来的数据返回到我们的代理服务器中,代理服务器再返回数据给我们的客户端,这样我们就可以实现跨域访问数据啦。
    在这里插入图片描述
    理解了这个原理之后,我们就可以按照这个逻辑去配置了。
    打开config/index.js,在proxyTable中添写如下代码:
proxyTable: {
       '/api':{
         target:'http://www.xxxxxxxx.com/',//跨域的地址
         changeOrigin: true,//是否跨域
         pathRewrith:{
           '^/api':''
         }
       }
    },

使用:

// 商品列表
  list (listParams) {
    return _http.request({
      type: 'post',
      url: '/mall/product/list.do',//直接调取接口
      data: listParams
    })
  }

就可以正常发送ajax请求了。

  • 第三种:jquery jsonp

$.ajax({ 
      url: '地址', 
      type: 'GET', 
      dataType: 'JSONP', 
      success: function (res) { 
        self.data = res.data.slice(0, 3)
        self.opencode = res.data[0].opencode.split(',') 
      } 
    }) 
### Vue3 中解决问题的方法 在开发基于前端框架的应用程序时,资源共享 (CORS) 是常见的挑战之一。Vue3 提供了几种方法来处理这个问题。 #### 方法一:通过后端设置 CORS 头部 如果开发者有权限修改服务器端代码,则可以通过调整 HTTP 响应头允许特定名访问资源[^1]。例如,在 Express.js 的 Node.js 后端中可以这样实现: ```javascript const express = require('express'); const cors = require('cors'); const app = express(); app.use(cors({ origin: 'http://localhost:8080', // 替换为前端应用的实际地址 })); app.get('/data', (req, res) => { res.json({ message: 'This is data from the server.' }); }); app.listen(5000, () => console.log('Server running on port 5000')); ``` 这种方法适用于生产环境中的长期解决方案。 #### 方法二:使用本地代理配置 对于开发阶段的请求,推荐使用 Webpack Dev Server 配置代理功能。由于 Vue CLI 默认集成了 Webpack 开发服务器,因此可以在 `vue.config.js` 文件中定义代理规则[^2]。 以下是具体的配置方式: ```javascript module.exports = { devServer: { proxy: { '/api': { // 将 /api 路径下的请求转发到目标服务器 target: 'http://example.com', changeOrigin: true, pathRewrite: { '^/api': '' } // 可选路径重写逻辑 } } } }; ``` 上述配置会将所有匹配 `/api` 的请求发送至指定的目标 URL (`http://example.com`) 并伪装成该源发出的请求。 #### 方法三:JSONP 技术(不建议) 尽管 JSONP 是一种较早的技术用于绕过浏览器同源策略限制,但由于其安全性较低以及仅支持 GET 请求,通常不再作为首选方案[^3]。 --- ### 总结 针对 Vue3 应用中的问题,最常见的方式是在服务端启用 CORS 支持或者利用客户端工具如 Webpack 进行反向代理。前者适合部署后的实际场景需求;后者则更适合于开发调试期间快速解决问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值