請(qǐng)看下面我的回答(下客介),來(lái)個(gè)人幫幫,不想再熬夜了。感謝
不懂后端,望提供前端可以解決的方案,感謝
1-fetch跨域請(qǐng)求"聚合數(shù)據(jù)"提供的新聞API,報(bào)“ 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截圖:
我請(qǐng)求的是聚合數(shù)據(jù)的新聞?lì)^條api。采用 webpack-dev-server --history-api-fallback
啟動(dòng)前端行項(xiàng)目,在在webpack.config.js 里面添加proxy 配置。采用isomorphic-fetch 來(lái)請(qǐng)求資源的。
我采用的是"justfine"的第三種方案(見(jiàn)回答),參考的是中的方法2.但還是報(bào)同樣的錯(cuò)誤,不明白哪里出現(xiàn)了問(wèn)題,望知情者給予解答,十分感謝。
其中‘二月’回復(fù)我說(shuō)——"proxy做的是轉(zhuǎn)發(fā)請(qǐng)求,因?yàn)楫?dāng)前域名和目標(biāo)域名不一樣,而目標(biāo)域名沒(méi)有設(shè)置允許跨域,proxy將當(dāng)前域名的請(qǐng)求切換到目標(biāo)域名去請(qǐng)求,就避開(kāi)了跨域"
我的理解是當(dāng)前域名為'localhost
',目標(biāo)域名為'v.juhe.cn/toutiao/index?type=top&key=..
'目標(biāo)域名(聚合數(shù)據(jù))即服務(wù)器沒(méi)有實(shí)現(xiàn)CORS接口。
我參考‘二月’與‘justfine’以及‘王下邀月熊_Chevalier’瀏覽器跨域方法與基于Fetch的Web請(qǐng)求最佳實(shí)踐的說(shuō)法,采用的便是Proxy:服務(wù)端跨域(代理方式跨域),SOP的限制是瀏覽器實(shí)現(xiàn)的。如果請(qǐng)求不是從瀏覽器發(fā)起的,就不存在跨域問(wèn)題了。
我將新聞?lì)^條API換成美團(tuán)API 現(xiàn)在報(bào)的新錯(cuò)誤是Uncaught (in promise) SyntaxError: Unexpected token < in JSON at position 0
fetch:
webpack.cinfig.js:
報(bào)錯(cuò)信息:
network信息:
下面這圖讓我感覺(jué)根本沒(méi)請(qǐng)求到數(shù)據(jù)——————還是說(shuō)請(qǐng)求的json有問(wèn)題導(dǎo)致的:
下面是Postman測(cè)試接口返回的數(shù)據(jù),我用json在線解析式圖看了一下,返回的json沒(méi)問(wèn)題
console打印結(jié)果。console.log(response)
看你的配置:
配置有問(wèn)題,target
你配置域名就行了,不用具體到某一個(gè)api,這樣當(dāng)你訪問(wèn)http://localhost:8080/api/toutiao/index
時(shí),會(huì)被代理轉(zhuǎn)發(fā)到這個(gè)地址:
http://v.juhe.cn/toutiao/index
再看你的請(qǐng)求,你使用的是http://v.juhe.cn/toutiao/index
來(lái)請(qǐng)求,還把請(qǐng)求頭的origin給改了,這樣你配置代理的作用何在?所以你應(yīng)該用http://localhost:8080/api/toutiao/index
來(lái)發(fā)請(qǐng)求,這樣才能走你設(shè)置的代理,跟CORS沒(méi)關(guān)系,是你使用代理的姿勢(shì)不對(duì)!
建議題主再仔細(xì)看一下http-proxy-middleware的用法哈
謝邀
前端解決方案給你倆種
1 項(xiàng)目中配置proxy代理,我看你圖中配置了代理 但是錯(cuò)誤點(diǎn)是 路徑有問(wèn)題
舉個(gè)例子 http://www.aaa.com/abc.do 或 http://www.aaa.com/deg.do 這種接口
你target 應(yīng)該為 http://www.aaa.com
項(xiàng)目使用 /api/abc.do 這樣去調(diào)取接口
2 本地配置host 修改host為你訪問(wèn)的接口 然后域名訪問(wèn)項(xiàng)目 xxx yyy 百度即可很簡(jiǎn)單
謝邀!首先錯(cuò)誤信息是服務(wù)器端頭部匹配時(shí)出現(xiàn)不匹配現(xiàn)象,即未設(shè)置Access-Control-Allow-Origin
。
解決跨域一般采用下面幾種方法:
1.JSONP方式解決跨域問(wèn)題
jsonp解決跨域問(wèn)題是一個(gè)比較古老的方案(實(shí)際中不推薦使用),其中jsonp只能是“GET”請(qǐng)求,不能進(jìn)行較為復(fù)雜的POST和其它請(qǐng)求。
2.CORS解決跨域問(wèn)題
CORS需要瀏覽器和服務(wù)器同時(shí)支持。其中通信的關(guān)鍵是服務(wù)器,要想跨源通信,服務(wù)器必須實(shí)現(xiàn)CORS接口。
3.代理請(qǐng)求方式解決接口跨域問(wèn)題
代理請(qǐng)求主要是對(duì)接口進(jìn)行代理,前端ajax請(qǐng)求的是本地接口,本地接口接收到請(qǐng)求后向?qū)嶋H的接口請(qǐng)求數(shù)據(jù),然后再將信息返回給前端,node.js即可代理。
4.瀏覽器插件
谷歌瀏覽器跨域插件:Allow-Control-Allow-Origin
北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
北大青鳥(niǎo)中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過(guò)二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。