国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 15:39:50
字體:
供稿:網(wǎng)友

本篇博客主要說明:

前后端框架(本例中是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模塊(成功,解決跨域問題,并正確返回?cái)?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ù)器的原因。

為什么這么說?

因?yàn)樵诜?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)用。

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

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

所以說,前端開發(fā)模塊化編程趨勢下,nodejs必須要會,因?yàn)槎叨际窃趶?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ù)已啟動");

題外話:

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

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

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

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

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

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

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 宁阳县| 灵丘县| 北川| 四平市| 新疆| 阳江市| 潢川县| 兴安县| 余干县| 宜宾县| 阳城县| 塔城市| 大悟县| 苗栗市| 普兰店市| 肥城市| 贵溪市| 乌拉特后旗| 陈巴尔虎旗| 防城港市| 大足县| 郸城县| 客服| 桓台县| 昌宁县| 双辽市| 连城县| 南雄市| 湟中县| 黑山县| 甘南县| 定远县| 浦东新区| 内黄县| 东山县| 大港区| 宿松县| 牡丹江市| 祁阳县| 临猗县| 蛟河市|