這篇文章將為大家詳細(xì)講解有關(guān)vue框架與koa框架通信及服務(wù)器跨域配置的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
10年積累的成都網(wǎng)站制作、網(wǎng)站建設(shè)經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先做網(wǎng)站設(shè)計后付款的網(wǎng)站建設(shè)流程,更有東烏珠穆沁免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。前后端框架(本例中是vue和koa)如何發(fā)送請求?獲取響應(yīng)?
以及跨域問題如何解決?
vue部分:
import App from './App.vue' import Axios from 'axios' new Vue({ el: '#app', render: h => h(App), mounted(){ Axios({ method: 'get', url: 'http://localhost:3000', }).then((response) => { console.log(response); }) } })
koa部分:
const Koa = require('koa'); const cors = require('koa-cors'); const app = new Koa(); const main = ctx => { ctx.response.body = 'Hello World'; }; app.use(cors()); app.use(main); app.listen(3000); console.log("服務(wù)已啟動");
坑集錦:
1.單純引入koa框架并且開啟服務(wù),會出現(xiàn)跨域錯誤
XMLHttpRequest cannot load http://localhost:3000/. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:8080';; is therefore not allowed access. bundle.js:1200 Uncaught (in promise) Error: Network Error at createError (bundle.js:1200) at XMLHttpRequest.handleError (bundle.js:1046)
2.跨域方案嘗試
①引入cors模塊(失敗,TypeError: res.setHeader is not a function)
const cors = require('cors'); app.use(cors());
②引入koa-cors模塊(成功,解決跨域問題,并正確返回數(shù)據(jù))
const cors = require('koa-cors'); app.use(cors())
此時會在新的http response的頭部信息中會新增2個字段。
Access-Control-Allow-Methods:GET,HEAD,PUT,POST,DELETEAccess-Control-Allow-Origin:http://localhost:8080
現(xiàn)在我們來宏觀分析一下,跨域失敗以及成功的深層次原因是什么?
客戶端(http://localhost:8080)
服務(wù)端:(http://localhost:3000)
跨域請求失敗是誰的原因?
服務(wù)器的原因。
為什么這么說?
因為在服務(wù)器端引入koa-cors之前,注意,是服務(wù)器端,我們的跨域訪問失敗。
而在服務(wù)器引入跨域請求模塊koa-cors之后,而客戶端沒有做任何改變,跨域訪問就成功了。
具體來說,就是在返回的請求頭里加入了2個跨域請求的字段,上文也給出了詳細(xì)的HTTP定義。
一個代表支持的請求方法,本例中是get方法。
一個代表允許使用上述方法的域,本例中是http://localhost:8080。
1.那么聰明的你就會問了,koa-cors本質(zhì)上是一個node模塊,這個模塊是怎么做到支持跨域訪問到呢?
我想koa-cors肯定調(diào)用了node模塊http,其余模塊暫時未知。
2.那么聰明的你又會想到,axios呢,它的內(nèi)部工作原理是什么?
我想肯定用到了的XMLHttpRequest這個對象,基于XMR對象做了封裝,暫且知道這么多。
3.所以說聰明的你會有一個領(lǐng)悟!
node模塊不止是能在服務(wù)器端調(diào)用,在客戶端也可以調(diào)用。
說清楚一點,就是node模塊不止能夠封裝node.js引擎的api,而且能封裝web V8引擎的api。
若是想問原因的話,我想是因為node是基于V8y引擎開發(fā)的服務(wù)器環(huán)境,因此v8 api基本上是通用的,暫時這么理解。
所以說,前端開發(fā)模塊化編程趨勢下,nodejs必須要會,因為二者都是在強大的V8引擎驅(qū)動下工作的。
最后說個微觀的坑...
下面的代碼中,app.use(cors());必須在app.use(main);之前。
const Koa = require('koa'); const cors = require('koa-cors'); const app = new Koa(); const main = ctx => { ctx.response.body = 'Hello World'; }; app.use(cors()); app.use(main); app.listen(3000); console.log("服務(wù)已啟動");
關(guān)于“vue框架與koa框架通信及服務(wù)器跨域配置的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。