久久久精品一区ed2k-女人被男人叉到高潮的视频-中文字幕乱码一区久久麻豆樱花-俄罗斯熟妇真实视频

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

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

成都創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),巫溪企業(yè)網(wǎng)站建設(shè),巫溪品牌網(wǎng)站建設(shè),網(wǎng)站定制,巫溪網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,巫溪網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

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

以及跨域問題如何解決?

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ù)已啟動");

坑集錦:

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

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

現(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必須要會,因為二者都是在強(qiáng)大的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é)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

分享文章:vue框架與koa框架通信及服務(wù)器跨域配置的示例分析
URL分享:http://sd-ha.com/article12/iecdgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、App設(shè)計、建站公司、網(wǎng)站策劃外貿(mào)網(wǎng)站建設(shè)、用戶體驗

廣告

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

h5響應(yīng)式網(wǎng)站建設(shè)