亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

客戶端(vue框架)與服務(wù)器(koa框架)通信及服務(wù)器跨域配置詳解

 更新時(shí)間:2017年08月26日 16:01:12   作者:趁你還年輕233  
本篇文章主要介紹了客戶端(vue框架)與服務(wù)器(koa框架)通信及服務(wù)器跨域配置詳解,具有一定的參考價(jià)值,有興趣的可以了解一下

本篇博客主要說明:

前后端框架(本例中是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ù)已啟動(dòng)");

坑集錦:

1.單純引入koa框架并且開啟服務(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模塊(成功,解決跨域問題,并正確返回?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

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

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

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

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

為什么這么說?

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

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

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

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

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

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

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

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

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

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

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

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

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

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

最后說個(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)");

題外話:

和學(xué)長吃中飯的過程中,討論到webkit,gecko和v8.以及手機(jī)瀏覽器和桌面瀏覽器的區(qū)別。

主要總結(jié)出幾點(diǎn):

1.v8是webkit的js引擎,Gecko有自己的js引擎。

2.PC端和移動(dòng)端,統(tǒng)一理解成webkit端就行。

因?yàn)閟afari和chrome都是webkit內(nèi)核,可以類比safari為蘋果手機(jī),chrome類比為android手機(jī)。

由此推理出安卓手機(jī)和蘋果手機(jī)自帶瀏覽器都是webkit內(nèi)核。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue異步加載高德地圖的實(shí)現(xiàn)

    vue異步加載高德地圖的實(shí)現(xiàn)

    這篇文章主要介紹了vue異步加載高德地圖的實(shí)現(xiàn),詳細(xì)的介紹了異步加載的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • vue3 使用socket的完整代碼

    vue3 使用socket的完整代碼

    這篇文章主要介紹了vue3 使用socket的完整代碼,包括vue3客戶端和服務(wù)端的實(shí)例講解,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • Vue中的this.$options.data()和this.$data用法說明

    Vue中的this.$options.data()和this.$data用法說明

    這篇文章主要介紹了Vue中的this.$options.data()和this.$data用法說明,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • el-table?fixed固定列導(dǎo)致錯(cuò)位的解決方法介紹

    el-table?fixed固定列導(dǎo)致錯(cuò)位的解決方法介紹

    ElementUI中el-table設(shè)置指定列固定不動(dòng),不受滾動(dòng)條影響,下面這篇文章主要給大家介紹了關(guān)于el-table?fixed固定列導(dǎo)致錯(cuò)位的解決方法,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • vue項(xiàng)目element UI input框掃碼槍掃描過快出現(xiàn)數(shù)據(jù)丟失問題及解決方案

    vue項(xiàng)目element UI input框掃碼槍掃描過快出現(xiàn)數(shù)據(jù)丟失問題及解決方案

    這篇文章主要介紹了vue項(xiàng)目element UI input框掃碼槍掃描過快出現(xiàn)數(shù)據(jù)丟失問題,輸入框要掉兩個(gè)接口,根據(jù)第一個(gè)驗(yàn)證接口返回的code,彈不同的框,點(diǎn)擊彈框確認(rèn)再掉第二個(gè)接口,需要的朋友可以參考下
    2022-12-12
  • Vue?props傳入function時(shí)的this指向問題解讀

    Vue?props傳入function時(shí)的this指向問題解讀

    這篇文章主要介紹了Vue?props傳入function時(shí)的this指向問題解讀,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue2中配置Cesium全過程

    Vue2中配置Cesium全過程

    這篇文章主要介紹了Vue2中配置Cesium全過程,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vuejs實(shí)現(xiàn)遞歸樹型菜單組件

    vuejs實(shí)現(xiàn)遞歸樹型菜單組件

    本篇文章主要介紹了vuejs實(shí)現(xiàn)遞歸樹型菜單組件,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • 前端vue如何使用pptxgen.js導(dǎo)出PPT

    前端vue如何使用pptxgen.js導(dǎo)出PPT

    最近公司項(xiàng)目有個(gè)導(dǎo)出ppt的功能,在使用ppexgen.js一周完成功能之后,這篇文章主要給大家介紹了關(guān)于前端vue如何使用pptxgen.js導(dǎo)出PPT的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • Vue?+?Element?自定義上傳封面組件功能

    Vue?+?Element?自定義上傳封面組件功能

    這篇文章主要介紹了Vue?+?Element?自定義上傳封面組件,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-01-01

最新評論