客戶端(vue框架)與服務器(koa框架)通信及服務器跨域配置詳解
本篇博客主要說明:
前后端框架(本例中是vue和koa)如何發(fā)送請求?獲取響應?
以及跨域問題如何解決?

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("服務已啟動");
坑集錦:
1.單純引入koa框架并且開啟服務,會出現跨域錯誤
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模塊(成功,解決跨域問題,并正確返回數據)
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

現在我們來宏觀分析一下,跨域失敗以及成功的深層次原因是什么?
客戶端(http://localhost:8080)
服務端:(http://localhost:3000)
跨域請求失敗是誰的原因?
服務器的原因。
為什么這么說?
因為在服務器端引入koa-cors之前,注意,是服務器端,我們的跨域訪問失敗。
而在服務器引入跨域請求模塊koa-cors之后,而客戶端沒有做任何改變,跨域訪問就成功了。
具體來說,就是在返回的請求頭里加入了2個跨域請求的字段,上文也給出了詳細的HTTP定義。
一個代表支持的請求方法,本例中是get方法。
一個代表允許使用上述方法的域,本例中是http://localhost:8080。
1.那么聰明的你就會問了,koa-cors本質上是一個node模塊,這個模塊是怎么做到支持跨域訪問到呢?
我想koa-cors肯定調用了node模塊http,其余模塊暫時未知。
2.那么聰明的你又會想到,axios呢,它的內部工作原理是什么?
我想肯定用到了的XMLHttpRequest這個對象,基于XMR對象做了封裝,暫且知道這么多。
3.所以說聰明的你會有一個領悟!
node模塊不止是能在服務器端調用,在客戶端也可以調用。
說清楚一點,就是node模塊不止能夠封裝node.js引擎的api,而且能封裝web V8引擎的api。
若是想問原因的話,我想是因為node是基于V8y引擎開發(fā)的服務器環(huán)境,因此v8 api基本上是通用的,暫時這么理解。
所以說,前端開發(fā)模塊化編程趨勢下,nodejs必須要會,因為二者都是在強大的V8引擎驅動下工作的。
最后說個微觀的坑...
下面的代碼中,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("服務已啟動");
題外話:
和學長吃中飯的過程中,討論到webkit,gecko和v8.以及手機瀏覽器和桌面瀏覽器的區(qū)別。
主要總結出幾點:
1.v8是webkit的js引擎,Gecko有自己的js引擎。
2.PC端和移動端,統(tǒng)一理解成webkit端就行。
因為safari和chrome都是webkit內核,可以類比safari為蘋果手機,chrome類比為android手機。
由此推理出安卓手機和蘋果手機自帶瀏覽器都是webkit內核。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Vue中的this.$options.data()和this.$data用法說明
這篇文章主要介紹了Vue中的this.$options.data()和this.$data用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
vue項目element UI input框掃碼槍掃描過快出現數據丟失問題及解決方案
這篇文章主要介紹了vue項目element UI input框掃碼槍掃描過快出現數據丟失問題,輸入框要掉兩個接口,根據第一個驗證接口返回的code,彈不同的框,點擊彈框確認再掉第二個接口,需要的朋友可以參考下2022-12-12
Vue?props傳入function時的this指向問題解讀
這篇文章主要介紹了Vue?props傳入function時的this指向問題解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01

