在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/HTML/ react 使用fetch跨域報No 'Access-Control-Allow

react 使用fetch跨域報No 'Access-Control-Allow-Origin'

請看下面我的回答(下客介),來個人幫幫,不想再熬夜了。感謝

不懂后端,望提供前端可以解決的方案,感謝

1-fetch跨域請求"聚合數(shù)據(jù)"提供的新聞API,報“ No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:8080' is therefore not allowed access. If an opaque response serves your needs, set the request's mode to 'no-cors' to fetch the resource with CORS disabled.”

2-相關(guān)代碼段
webpack.config.js片段:
安裝了:

var proxy = require('http-proxy-middleware');
require('es6-promise').polyfill();
require('isomorphic-fetch')

;
圖片描述

xxx.js片段:
圖片描述

3-瀏覽器console與network截圖:

圖片描述

圖片描述
圖片描述
圖片描述

回答
編輯回答
青裙

1、修改host文件,映射到v.juhe.cn
圖片描述

2、chrome跨域
--disable-web-security --user-data-dir
具體百度一下。
圖片描述

2018年4月10日 05:51
編輯回答
孤影

我請求的是聚合數(shù)據(jù)的新聞頭條api。采用 webpack-dev-server --history-api-fallback 啟動前端行項目,在在webpack.config.js 里面添加proxy 配置。采用isomorphic-fetch 來請求資源的。

我采用的是"justfine"的第三種方案(見回答),參考的是中的方法2.但還是報同樣的錯誤,不明白哪里出現(xiàn)了問題,望知情者給予解答,十分感謝。

其中‘二月’回復我說——"proxy做的是轉(zhuǎn)發(fā)請求,因為當前域名和目標域名不一樣,而目標域名沒有設置允許跨域,proxy將當前域名的請求切換到目標域名去請求,就避開了跨域"

我的理解是當前域名為'localhost',目標域名為'v.juhe.cn/toutiao/index?type=top&key=..'目標域名(聚合數(shù)據(jù))即服務器沒有實現(xiàn)CORS接口。

我參考‘二月’與‘justfine’以及‘王下邀月熊_Chevalier’瀏覽器跨域方法與基于Fetch的Web請求最佳實踐的說法,采用的便是Proxy:服務端跨域(代理方式跨域),SOP的限制是瀏覽器實現(xiàn)的。如果請求不是從瀏覽器發(fā)起的,就不存在跨域問題了。

我將新聞頭條API換成美團API 現(xiàn)在報的新錯誤是Uncaught (in promise) SyntaxError: Unexpected token < in JSON at position 0

fetch:
圖片描述

webpack.cinfig.js:

圖片描述

報錯信息:

圖片描述

network信息:

圖片描述

下面這圖讓我感覺根本沒請求到數(shù)據(jù)——————還是說請求的json有問題導致的
圖片描述

下面是Postman測試接口返回的數(shù)據(jù),我用json在線解析式圖看了一下,返回的json沒問題

圖片描述

console打印結(jié)果。console.log(response)

圖片描述

2017年10月16日 19:26
編輯回答
孤影

你在proxy里面都設置了代理請求匹配api路徑,但是沒有按照設置你請求的還是原地址當然不會給你代理
ajax 路徑 /api/toutiao...

2017年4月10日 23:26
編輯回答
孤島

前端 only 無解。

2018年5月17日 10:32
編輯回答
悶騷型

后端加請求頭。前端無解

2018年4月20日 11:37
編輯回答
過客

看你的配置:

clipboard.png

配置有問題,target你配置域名就行了,不用具體到某一個api,這樣當你訪問http://localhost:8080/api/toutiao/index時,會被代理轉(zhuǎn)發(fā)到這個地址:

http://v.juhe.cn/toutiao/index

再看你的請求,你使用的是http://v.juhe.cn/toutiao/index來請求,還把請求頭的origin給改了,這樣你配置代理的作用何在?所以你應該用http://localhost:8080/api/toutiao/index來發(fā)請求,這樣才能走你設置的代理,跟CORS沒關(guān)系,是你使用代理的姿勢不對!

建議題主再仔細看一下http-proxy-middleware的用法哈

2018年2月9日 11:58
編輯回答
凹凸曼

請求的headers里設置'Access-Control-Allow-Origin': '*'

2017年12月12日 20:47
編輯回答
不二心

謝邀

前端解決方案給你倆種

1  項目中配置proxy代理,我看你圖中配置了代理 但是錯誤點是 路徑有問題
舉個例子  http://www.aaa.com/abc.do 或 http://www.aaa.com/deg.do 這種接口
你target 應該為 http://www.aaa.com
項目使用   /api/abc.do 這樣去調(diào)取接口
2 本地配置host  修改host為你訪問的接口  然后域名訪問項目  xxx   yyy 百度即可很簡單
2017年12月6日 17:19
編輯回答
掛念你

謝邀!首先錯誤信息是服務器端頭部匹配時出現(xiàn)不匹配現(xiàn)象,即未設置Access-Control-Allow-Origin
解決跨域一般采用下面幾種方法:

1.JSONP方式解決跨域問題
jsonp解決跨域問題是一個比較古老的方案(實際中不推薦使用),其中jsonp只能是“GET”請求,不能進行較為復雜的POST和其它請求。

2.CORS解決跨域問題
CORS需要瀏覽器和服務器同時支持。其中通信的關(guān)鍵是服務器,要想跨源通信,服務器必須實現(xiàn)CORS接口。

3.代理請求方式解決接口跨域問題
代理請求主要是對接口進行代理,前端ajax請求的是本地接口,本地接口接收到請求后向?qū)嶋H的接口請求數(shù)據(jù),然后再將信息返回給前端,node.js即可代理。

4.瀏覽器插件
谷歌瀏覽器跨域插件:Allow-Control-Allow-Origin

clipboard.png

2018年8月6日 09:02
編輯回答
筱饞貓

跨域的問題,請查詢CORS關(guān)鍵字。解決方法,必須后端的響應頭加上'Access-Control-Allow-Origin': '*' ?;蛘咧付ň唧w的域名。 前端不可能控制的。

2018年9月18日 18:52