vue如何解决跨域的问题,有哪几种方式?

这篇具有很好参考价值的文章主要介绍了vue如何解决跨域的问题,有哪几种方式?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在使用axios发送请求之后,没有得到返回的数据,打开控制台发现如下图所示的报错:

vue如何解决跨域的问题,有哪几种方式?

这是提示跨域了。所有使用JavaScript的浏览器都会支持同源策略。同源策略即指域名/协议/端口号相同。只要有一个不同,就会当作跨域请求。 

解决方法为:

1. CORS

后端通过 CORS 解决跨域,在响应头中添加:

Access-Control-Allow-Origin: <origin> 

前端就可以通过 axios 跨域访问该后端 API。

2. proxy

在 vue.config.js 中配置 proxy 代理跨域:

module.exports = {
  devServer: {
    proxy: {
      '/api': {
        target: 'http://localhost:8080',
        changeOrigin: true
      }
    }
  }  
} 

这样前端请求 '/api' 会被代理到 'http://localhost:8080',实现跨域。

3. JSONP

通过动态创建 <script> 标签跨域获取数据:

function getdata(url, callback) {
  var script = document.createElement('script')
  script.src = url + '?callback=' + callback
  document.body.appendChild(script)
}

getdata('http://example.com/getdata?a=1', 'callback')

function callback(data) {
  console.log(data)
}

服务端返回的 JSON 数据会作为 callback 函数的参数,实现跨域数据获取。

4. postMessage

在跨域的两个 window 之间通信:

// window1
window.addEventListener('message', function(e) {
  console.log(e.data)  
}, false)

// window2
var win = otherWindow.window
win.postMessage('message', 'http://example.com')

其他方案还有 Web Sockets、nginx 代理等。

总结一下,解决vue跨域的方法有:

1. 后端通过 CORS 添加响应头
2. Vue CLI proxy 代理跨域
3. JSONP 通过动态 <script> 标签跨域
4. postMessage 跨 window 通信
5. Web Sockets
6. nginx 反向代理

理解跨域问题的原理和常用解决方案对前端工程师来说是非常重要的。文章来源地址https://www.toymoban.com/news/detail-477571.html

到了这里,关于vue如何解决跨域的问题,有哪几种方式?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 解决前端跨域的几种方法

    一、跨域报错         在我们实际开发过程中,都有遇到过跨域的问题,跨域报错如下: 二、为什么会报跨域?         跨域的本质是浏览器基于同源策略的一种安全手段,主要是考虑到用户的信息安全。何为同源策略呢?同源策略是一种约定,它是浏览器最核心也

    2024年02月09日
    浏览(51)
  • 电子商务有哪几种模式

    电子商务通常是指在全球各地广泛的商业贸易活动中,在因特网开放的网络环境下,基于客户端/服务端应用方式,买卖双方不谋面地进行各种商贸活动,实现消费者的网上购物、商户之间的网上交易和在线电子支付以及各种商务活动、交易活动、金融活动和相关的综合服务活

    2024年02月13日
    浏览(55)
  • 运行 Spring Boot 有哪几种方式?

    目录 一、打包用命令或者放到容器中运行 二、用 Maven 插件运行 三、用  Gradle 插件运行 四、直接执行 main 方法运行   通过打包和放到容器中运行SpringBoot项目有以下几种方式: 打包为Jar文件: 使用Maven或Gradle等构建工具,执行打包命令将SpringBoot项目打包为可执行的Jar文件。

    2024年02月13日
    浏览(47)
  • 机器视觉工程师,有哪几种类型

    1.光学实验室(打光机器视觉工程师,一般此职位,要求有光学学历的背景最佳) 2.机器视觉算法开发工程师(此职位国内稀缺)3.机器视觉工程师/机器视觉开发工程师(MV工程师/MV工程师)(国内岗位需求量最多的) 3.机器视觉工程师/机器视觉开发工程师(MV工程师/MV工程师

    2024年02月10日
    浏览(53)
  • 【Java】线程都有哪几种状态

    首先我们要知道,在传统(操作系统)的线程模型中线程被分为五种状态,在java线程中,线程被分为六种状态。 线程的五种状态: 新建(new) 创建了一个新的线程对象 就绪(runnable) 调用线程的start()方法,处于就绪状态 运行(running) 获得了CPU时间片,执行程序代码 就绪

    2024年02月09日
    浏览(56)
  • MySQL基础扎实——MySQL中有哪几种锁

    在MySQL中,常见的锁包括以下几种: 表级锁(Table-level Lock) :表级锁是对整张表进行锁定,可以分为两种类型: 共享锁(Shared Lock) :也称为读锁(Read Lock),多个事务可以同时持有共享锁,且不互斥。共享锁适用于读操作,不阻塞其他事务的读操作。 排他锁(Exclusive L

    2024年02月15日
    浏览(50)
  • 面试必问:RabbitMQ 有哪几种消息模式?

    原文:juejin.cn/post/6998363970037874724 Rabbitmq 是使用 Erlang 语言开发的开源消息队列系统,基于 AMQP 实现,是一种应用程序对应用程序的通信方法,应用程序通过读写出入队列的消息来通信,而无需专用连接来链接它们。消息传递指的是应用程序之间通过在消息中发送数据进行通信

    2024年02月06日
    浏览(50)
  • 网页爬虫中常用代理IP主要有哪几种?

    各位爬虫探索者,你是否有想过在网页爬虫中使用代理IP来规避限制实现数据自由?在这篇文章中,作为一名IP代理产品供应商,我将为你揭示常见的网页爬虫代理IP类型,让你在爬虫的世界中游刃有余! 一、免费公开代理IP: 这是最常见的一种代理IP类型。它们通常是一些公

    2024年02月13日
    浏览(55)
  • 有哪几种行为会导致服务器被入侵

    导致服务器被入侵的行为有很多种,以下是一些常见的行为: 系统漏洞:服务器操作系统或软件存在漏洞,攻击者可以通过利用这些漏洞获取系统权限,从而入侵服务器。 弱口令:服务器的账号密码过于简单或者未及时更新,攻击者可以通过暴力破解等手段获取系统权限,

    2024年02月22日
    浏览(51)
  • Java list 根据id获取对象 有哪几种方式

    在 Java 中,有以下几种方法来根据 ID 获取列表中的对象: 循环遍历列表:遍历整个列表,比较每个对象的 ID 和目标 ID,如果匹配,就返回该对象。 使用 Stream API:使用 Java 8 的 Stream API 操作列表,并使用 filter() 方法筛选出具有指定 ID 的对象。 使用 Map:将对象存储在 Map 中

    2024年02月11日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包