跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • 无法解决 vue 跨域的问题
未分類
16 7 月 2020

无法解决 vue 跨域的问题

无法解决 vue 跨域的问题

資深大佬 : LizzZzzQun 11

小白一枚,设置了 vue.config.ja 中的 proxy 没有用,控制台依旧显示是跨域的问题,我的接口是能正常访问数据的,

大佬有話說 (15)

  • 資深大佬 : CHNpeople

    重启了吗?

  • 資深大佬 : xuanbg

    让你的接口支持 CROS 就好了

  • 資深大佬 : fengxianqi

    axios.get(‘/api/aa’)

    请求不能带外域

  • 資深大佬 : edk24

    跨域从后端很好解决.

    接口响应加 CROS 头, nginx 也配置一下

    location / {
    add_header Access-Control-Allow-Origin *;
    add_header Access-Control-Allow-Methods ‘GET, POST, OPTIONS’;
    add_header Access-Control-Allow-Headers ‘DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization’;

    if ($request_method = ‘OPTIONS’) {
    return 204;
    }
    }

  • 資深大佬 : f056917

    @fengxianqi 我上次也是用 nginx 代理跨域,但是页面一直报错跨域,最后发现是请求带外域了[dog]

  • 資深大佬 : f056917

    vue.config.js 修改完了记得重启项目

  • 資深大佬 : meteor957

    跨域是浏览器的问题

  • 資深大佬 : suzic

    proxy 设置了一般就没问题了,主怎么设置的?

  • 資深大佬 : cyrbuzz

    跨域啊…

    跨域是浏览器端做的限制,所解决的核心问题是浏览器会自动为请求携带 cookies 信息导致的不安全问题。

    常规的解决方案一个是绕过,另一个是放行。

    先说放行,放行需要服务器端配合,为请求的 response 添加 CORS 头信息,当然并不一定要在服务器端做,只要在到达浏览器前这个 response 里携带了 CORS 头信息就好。

    再说绕过,绕过即是 vue 等所做 proxy 的原理,上面说到跨域其实是浏览器所做的限制,而 proxy 所做的是用 Node 做一次转发,Node 脱离了浏览器环境不受跨域限制而此时你再通过这个 Node 得到返回内容,所以想要 proxy 生效,你要做的是确保你的请求经过的是 proxy 。

    假如你的域是`localhost:8080`,proxy 设置的`/api`,目标是`www.baidu.com`。设置 proxy 之后请求的是`http://www.baidu.com/api/xxx`,这样是否能跨域取决于 www.baidu.com 是否设置了跨域,此时的流程是 应用程序 -> baidu -> 浏览器 -> 应用程序。理想状态应该是 应用程序 -> 代理 -> baidu -> 代理 -> 浏览器 -> 应用程序。

  • 資深大佬 : QingStone

    新增 /修改 vue.config.js ,都是需要重启项目运行的。
    另外,最好贴下代码,看看你咋配置的

  • 資深大佬 : shuiniushushu

    使用 vue.config.js 配置代理:
    “`js
    module.exports = {
    …
    devServer: {
    proxy: {
    ‘xxx/index.php’: {
    target: ‘https://xxx.yyy.com/’,
    },
    }
    }
    …
    }
    “`

  • 資深大佬 : yaphets666

    首先 proxy 只是配置 webpack-dev-server 的代理 proxy:{“/api”:{……}}假如这样写的话 那么 你去前端需要跨域的接口 都要加”/api”前缀 就是”/api/getSomething” 生产环境的代理需要 nginx 配置

  • 主 資深大佬 : LizzZzzQun

    问题解决了,是 CORS 的问题,我在 apache 中设置了 Access-Control-Allow-Origin: *以后,可以正常的读取数据了,谢谢各位老哥的帮忙!!

  • 主 資深大佬 : LizzZzzQun

    @edk24 加了以后就好了

  • 資深大佬 : darknoll

    @LizzZzzQun 问题不是这样解决的,你 devserver 配好了还要什么 cors

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具