日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

vue如何配置服务器端跨域_客户端(vue框架)与服务器(koa框架)通信及服务器跨域配置详解...

發布時間:2023/11/27 生活经验 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue如何配置服务器端跨域_客户端(vue框架)与服务器(koa框架)通信及服务器跨域配置详解... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本篇博客主要說明:

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

以及跨域問題如何解決?

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引擎開發的服務器環境,因此v8 api基本上是通用的,暫時這么理解。

所以說,前端開發模塊化編程趨勢下,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.以及手機瀏覽器和桌面瀏覽器的區別。

主要總結出幾點:

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

2.PC端和移動端,統一理解成webkit端就行。

因為safari和chrome都是webkit內核,可以類比safari為蘋果手機,chrome類比為android手機。

由此推理出安卓手機和蘋果手機自帶瀏覽器都是webkit內核。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

總結

以上是生活随笔為你收集整理的vue如何配置服务器端跨域_客户端(vue框架)与服务器(koa框架)通信及服务器跨域配置详解...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。