内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

vue框架與koa框架通信及服務(wù)器跨域配置的示例分析-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)vue框架與koa框架通信及服務(wù)器跨域配置的示例分析,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

10年積累的成都網(wǎng)站制作、網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先做網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有東烏珠穆沁免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

前后端框架(本例中是vue和koa)如何發(fā)送請(qǐng)求?獲取響應(yīng)?

以及跨域問(wèn)題如何解決?

vue框架與koa框架通信及服務(wù)器跨域配置的示例分析

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ù)已啟動(dòng)");

坑集錦:

1.單純引入koa框架并且開(kāi)啟服務(wù),會(huì)出現(xiàn)跨域錯(cuò)誤

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模塊(成功,解決跨域問(wèn)題,并正確返回?cái)?shù)據(jù))

const cors = require('koa-cors');
app.use(cors())

此時(shí)會(huì)在新的http response的頭部信息中會(huì)新增2個(gè)字段。

Access-Control-Allow-Methods:GET,HEAD,PUT,POST,DELETEAccess-Control-Allow-Origin:http://localhost:8080

vue框架與koa框架通信及服務(wù)器跨域配置的示例分析

現(xiàn)在我們來(lái)宏觀分析一下,跨域失敗以及成功的深層次原因是什么?

客戶端(http://localhost:8080)

服務(wù)端:(http://localhost:3000)

跨域請(qǐng)求失敗是誰(shuí)的原因?
服務(wù)器的原因。

為什么這么說(shuō)?

因?yàn)樵诜?wù)器端引入koa-cors之前,注意,是服務(wù)器端,我們的跨域訪問(wèn)失敗。

而在服務(wù)器引入跨域請(qǐng)求模塊koa-cors之后,而客戶端沒(méi)有做任何改變,跨域訪問(wèn)就成功了。

具體來(lái)說(shuō),就是在返回的請(qǐng)求頭里加入了2個(gè)跨域請(qǐng)求的字段,上文也給出了詳細(xì)的HTTP定義。

一個(gè)代表支持的請(qǐng)求方法,本例中是get方法。

一個(gè)代表允許使用上述方法的域,本例中是http://localhost:8080。

1.那么聰明的你就會(huì)問(wèn)了,koa-cors本質(zhì)上是一個(gè)node模塊,這個(gè)模塊是怎么做到支持跨域訪問(wèn)到呢?

我想koa-cors肯定調(diào)用了node模塊http,其余模塊暫時(shí)未知。

2.那么聰明的你又會(huì)想到,axios呢,它的內(nèi)部工作原理是什么?

我想肯定用到了的XMLHttpRequest這個(gè)對(duì)象,基于XMR對(duì)象做了封裝,暫且知道這么多。

3.所以說(shuō)聰明的你會(huì)有一個(gè)領(lǐng)悟!

node模塊不止是能在服務(wù)器端調(diào)用,在客戶端也可以調(diào)用。

說(shuō)清楚一點(diǎn),就是node模塊不止能夠封裝node.js引擎的api,而且能封裝web V8引擎的api。

若是想問(wèn)原因的話,我想是因?yàn)閚ode是基于V8y引擎開(kāi)發(fā)的服務(wù)器環(huán)境,因此v8 api基本上是通用的,暫時(shí)這么理解。

所以說(shuō),前端開(kāi)發(fā)模塊化編程趨勢(shì)下,nodejs必須要會(huì),因?yàn)槎叨际窃趶?qiáng)大的V8引擎驅(qū)動(dòng)下工作的。

最后說(shuō)個(gè)微觀的坑...

下面的代碼中,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ù)已啟動(dòng)");

關(guān)于“vue框架與koa框架通信及服務(wù)器跨域配置的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

標(biāo)題名稱:vue框架與koa框架通信及服務(wù)器跨域配置的示例分析-創(chuàng)新互聯(lián)
URL鏈接:http://www.rwnh.cn/article38/dgchsp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序網(wǎng)站制作、App設(shè)計(jì)、動(dòng)態(tài)網(wǎng)站、服務(wù)器托管、Google

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)
资兴市| 专栏| 涟水县| 太白县| 博客| 六盘水市| 贵定县| 高要市| 温宿县| 大新县| 荥经县| 方山县| 兰坪| 阳原县| 银川市| 广灵县| 连州市| 赣州市| 隆昌县| 仪陇县| 达州市| 敦化市| 西昌市| 彭阳县| 磴口县| 南澳县| 和田市| 万全县| 雷山县| 巴林左旗| 三台县| 新安县| 巴中市| 兰考县| 察雅县| 竹溪县| 定陶县| 新兴县| 伊川县| 大同市| 安平县|