
小白一枚,设置了 vue.config.ja 中的 proxy 没有用,控制台依旧显示是跨域的问题,我的接口是能正常访问数据的,
1 CHNpeople 2020-07-11 03:03:26 +08:00 重启了吗? |
2 xuanbg 2020-07-11 08:49:00 +08:00 让你的接口支持 CROS 就好了 |
3 fengxianqi 2020-07-11 08:57:36 +08:00 via Android axios.get('/api/aa') 请求不能带外域 |
4 edk24 2020-07-11 09:10:57 +08:00 跨域从后端很好解决. 接口响应加 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; } } |
5 p8YFk4f3E8SJ3aEv 2020-07-11 09:21:08 +08:00 @fengxianqi 我上次也是用 nginx 代理跨域,但是页面一直报错跨域,最后发现是请求带外域了[dog] |
6 p8YFk4f3E8SJ3aEv 2020-07-11 09:22:07 +08:00 vue.config.js 修改完了记得重启项目 |
| div class="fr"> 7 meteor957 2020-07-11 09:31:28 +08:00 跨域是浏览器的问题 |
8 suzic 2020-07-11 09:41:51 +08:00 via Android proxy 设置了一般就没问题了,楼主怎么设置的? |
9 cyrbuzz 2020-07-11 10:16:26 +08:00 跨域啊... 跨域是浏览器端做的限制,所解决的核心问题是浏览器会自动为请求携带 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 -> 代理 -> 浏览器 -> 应用程序。 |
10 QingStone 2020-07-11 10:24:28 +08:00 新增 /修改 vue.config.js ,都是需要重启项目运行的。 另外,最好贴下代码,看看你咋配置的 |
11 shuiniushushu 2020-07-11 12:45:49 +08:00 使用 vue.config.js 配置代理: ```js module.exports = { ... devServer: { proxy: { 'xxx/index.php': { target: 'https://xxx.yyy.com/', }, } } ... } ``` |
12 yaphets666 2020-07-11 13:03:43 +08:00 首先 proxy 只是配置 webpack-dev-server 的代理 proxy:{"/api":{......}}假如这样写的话 那么 你去前端需要跨域的接口 都要加"/api"前缀 就是"/api/getSomething" 生产环境的代理需要 nginx 配置 |
13 LizzZzzQun OP 问题解决了,是 CORS 的问题,我在 apache 中设置了 Access-Control-Allow-Origin: *以后,可以正常的读取数据了,谢谢各位老哥的帮忙!! |
14 LizzZzzQun OP @edk24 加了以后就好了 |
15 darknoll 2020-07-13 09:06:08 +08:00 @LizzZzzQun 问题不是这样解决的,你 devserver 配好了还要什么 cors |