我的编程空间,编程开发者的网络收藏夹
学习永远不晚

VUE如何解决跨域问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

VUE如何解决跨域问题

这篇文章主要介绍“VUE如何解决跨域问题”,在日常操作中,相信很多人在VUE如何解决跨域问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”VUE如何解决跨域问题”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

    跨域

    当我们遇到请求后台接口遇到 Access-Control-Allow-Origin 时,那说明跨域了。

    跨域是因为浏览器的同源策略所导致,同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,同源是指:域名、协议、端口相同

    VUE如何解决跨域问题

    解决跨域常用方法:

    一、VUE中常用proxy来解决跨域问题

    在vue.config.js中设置如下代码片段

    module.exports = {  dev: {    // Paths    assetsSubDirectory: 'static',    assetsPublicPath: '/',    proxyTable: { // 配置跨域    '/api':{        target:`http://www.baidu.com`, //请求后台接口        changeOrigin:true, // 允许跨域        pathRewrite:{            '^/api' : '' // 重写请求        }    }  },}

     2、创捷axioss实例时,将baseUrl设置为 ‘/api’

    const http = axios.create({  timeout: 1000 * 1000000,  withCredentials: true,  BASE_URL: '/api'  headers: {     'Content-Type': 'application/json; charset=utf-8'   }})

    二、JSONP解决跨域

    Jsonp(JSON with Padding) 是 json 的一种"使用模式",可以让网页从别的域名(网站)那获取资料,即跨域读取数据。

    <!DOCTYPE html>       <html>       <head>           <meta charset="utf-8">       </head>       <body>       <div id="textID"></div>       <script type="text/javascript">           function text_jsonp(req){               // 创建script的标签               var script = document.createElement('script');               // 拼接 url               var url = req.url + '?callback=' + req.callback.name;               // 赋值url               script.class="lazy" data-src = url;               // 放入头部               document.getElementsByTagName('head')[0].appendChild(script);           }       </script>       </body>       </html>

     三、CORS是跨域资源共享(Cross-Origin Resource Sharing),以 ajax 跨域请求资源,支持现代浏览器,IE支持10以上

    在CORS请求,头部信息中包含以下三个字段:

    Access-Control-Allow-Origin: 该字段是必须的。它的值要么是请求时Origin字段的值,要么是一个*,表示接受任意域名的请求,

    Access-Control-Allow-Credentials: 可选,值为布尔值,表示是否允许发送Cookie。默认情况下,Cookie不包括在CORS请求之中。设为true,即表示服务器明确许可,Cookie可以包含在请求中,一起发给服务器。这个值也只能设为true。如果要发送Cookie,Access-Control-Allow-Origin必须设置为必须指定明确的、与请求网页一致的域名

    Access-Control-Expose-Headers:可选。CORS请求时,XMLHttpRequest对象的getResponseHeader()方法只能拿到6个基本字段:Cache-ControlContent-LanguageContent-TypeExpiresLast-ModifiedPragma。如果想拿到其他字段,就必须在Access-Control-Expose-Headers里面指定

    详细讲解请查看阮大神的文章,传送门附上:CORS详解

    四、iframe实现跨域

    VUE如何解决跨域问题

    iframe(class="lazy" data-src){            //数组            if(Array.isArray(class="lazy" data-src)){                this.docs.visible = true;            }else{                this.docs.visible = false;                            }            this.link  = class="lazy" data-src            if(this.docs.visible == false){                if(this.$refs['ruleIframe'] && this.$refs['ruleIframe'].querySelector('iframe')){                    this.$refs['ruleIframe'].querySelector('iframe').remove()    //删除自身                }                var iframe = document.createElement('iframe');                iframe.width = '100%';                iframe.height = '100%';                iframe.setAttribute('frameborder','0')                iframe.class="lazy" data-src = class="lazy" data-src;                                this.append(iframe)            }                    },        //创建元素 防止  获取不到 ruleIframe 递归        append(iframe){            if(this.$refs['ruleIframe']){                this.$refs['ruleIframe'].appendChild(iframe);                return            }            setTimeout(()=>{                this.append(iframe);            },500)            },

    到此,关于“VUE如何解决跨域问题”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    VUE如何解决跨域问题

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    VUE如何解决跨域问题

    这篇文章主要介绍“VUE如何解决跨域问题”,在日常操作中,相信很多人在VUE如何解决跨域问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”VUE如何解决跨域问题”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
    2023-07-02

    vue-cli3跨域问题如何解决

    本篇内容介绍了“vue-cli3跨域问题如何解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1:将任何未知请求转发到代理服务器如:前端地址
    2023-07-04

    vue跨域问题怎么解决

    1、可以在后端服务器中进行配置,允许指定的域名或IP地址访问后端API,这样就可以解决跨域问题。常用的方法是在服务器端添加CORS(Cross-Origin Resource Sharing)配置。2、可以在Vue应用的配置文件中设置代理,
    2023-05-13

    Vue解决ajax跨域的问题

    这篇文章主要介绍了Vue解决ajax跨域的问题,跨域请求:是指协议名、主机名、端口号三者有任何一个不一样,而且跨域请求是请求发出去了,服务器接收并返回了结果,只是浏览器没有接收响应结果。感兴趣的同学可以参考阅读
    2023-05-14

    PHP跨域问题如何解决

    这篇文章主要讲解了“PHP跨域问题如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP跨域问题如何解决”吧!设置允许访问的域名:1、允许全部的域名访问header("Access-C
    2023-07-05

    iframe如何解决跨域问题

    iframe如何解决跨域问题,需要具体代码示例跨域问题是前端开发中常遇到的一个难题。由于浏览器的同源策略,页面中的JavaScript无法直接访问不同域名下的资源。解决这个问题有很多方法,其中之一便是使用iframe。什么是同源策略和跨域
    iframe如何解决跨域问题
    2024-02-22

    Vue3跨域问题如何解决

    这篇文章主要介绍了Vue3跨域问题如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue3跨域问题如何解决文章都会有所收获,下面我们一起来看看吧。vue项目配置代理vue.config.jsconst {
    2023-07-05

    jquery如何解决跨域问题

    jQuery提供多种方法解决跨域问题,包括JSONP、CORS、代理和预检请求。选择合适的方法取决于具体需求。本文详细介绍了每种方法,包括JSONP的JSON数据包装、CORS的服务器端配置、代理的中间人角色、预检请求的复杂请求检查,以及iframe的HTML结构嵌入。此外,本文还提到了其他方法,如postMessage()、WebSocket和FetchAPI。
    jquery如何解决跨域问题
    2024-04-02

    Ajax跨域问题如何解决

    这期内容当中小编将会给大家带来有关Ajax跨域问题如何解决,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。跨域跨域有三个条件,满足任何一个条件就是跨域 1:服务器端口不一致 2:协议不一致 3:域名不一致解
    2023-06-08

    django跨域问题如何解决

    Django跨域问题可以通过以下几种方法来解决:1. 使用Django的CORS插件:可以通过安装django-cors-headers插件来实现跨域访问的支持。安装插件后,在settings.py文件中添加以下配置:```pythonIN
    2023-09-26

    vue的跨域问题怎么解决

    这篇“vue的跨域问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue的跨域问题怎么解决”文章吧。在vue中,跨
    2023-07-04

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录