加入收藏 | 设为首页 | 会员中心 | 我要投稿 财气旺网 - 财气网 (https://www.caiqiwang.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

跨域是什么?vue怎样处理跨域的问题?

发布时间:2022-11-17 11:11:44 所属栏目:语言 来源:
导读:  这篇文章给大家分享的是跨域的相关内容,下文讲给大家介绍vue怎样解决跨域的问题,小编觉得挺实用的,因此分享给大家做个参考,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
  
  
  这篇文章给大家分享的是跨域的相关内容,下文讲给大家介绍vue怎样解决跨域的问题,小编觉得挺实用的,因此分享给大家做个参考,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
  
  一.什么是跨域
  
    跨域问题的出现是因为浏览器的同源策略问题,所谓同源:就是两个页面具有相同的协议(protocol),主机(host)和端口号(port),它是浏览器最核心也是最基本的功能,如果没有同源策略我们的浏览器将会十分的不安全,随时都可能受到攻击。
  
  
  二.如何解决跨域问题
  
    1.使用jsonp实现,网页通过script标签向服务器请求json数据,服务器受到请求后,将数据放在一个指定名字的回调函数的参数里面传给前端。
  
  <script src="http://www.test.com/getData?callback=getData"></script>
  // 向服务器test.com发出请求,该请求的查询字符串有一个callback参数,用来指定回调函数的名字
  
  // 处理服务器返回回调函数的数据
  <script type="text/javascript">
    // 服务器返回的数据会放到回调函数里面
    function getData(res){
      // 处理获得的数据
      console.log(res.data)
    }
  </script>
    2.使用Jquery ajax实现,
  
  $.ajax({
   url: 'http://www.test.com:8888/getData',
   type: 'get',
   dataType: 'jsonp', // 请求方式为jsonp
   jsonpCallback: "handleCallback",  // 自定义回调函数名
   data: {}
  })
    3.在vue开发中实现跨域:在vue项目根目录下找到vue.config.js文件(如果没有该文件则自己创建),在proxy中设置跨域
  
   devServer: {
    proxy: { //配置跨域
     '/api': {
      target: 'http://121.121.67.254:8185/', //这里后台的地址模拟的;应该填写你们真实的后台接口
      changOrigin: true, //允许跨域
      pathRewrite: {
       /* 重写路径,当我们在浏览器中看到请求的地址为:http://localhost:8080/api/core/getData/userInfo 时
        实际上访问的地址是:http://121.121.67.254:8185/core/getData/userInfo,因为重写了 /api
        */
       '^/api': ''
      }
     },
    }
   },
    在vue中使用proxy进行跨域的原理是:将域名发送给本地的服务器(启动vue项目的服务,loclahost:8080),再由本地的服务器去请求真正的服务器。
 

(编辑:财气旺网 - 财气网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!