請看下面我的回答(下客介),來個人幫幫,不想再熬夜了。感謝
不懂后端,望提供前端可以解決的方案,感謝
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截圖:
我請求的是聚合數(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)
看你的配置:
配置有問題,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的用法哈
謝邀!首先錯誤信息是服務器端頭部匹配時出現(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
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產(chǎn)業(yè)為響應國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復興的升級產(chǎn)業(yè)鏈。利用北京大學優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓領域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。