欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Node 代理訪問的實現(xiàn)

 更新時間:2019年09月19日 09:23:53   作者:D_Q_  
這篇文章主要介紹了Node 代理訪問的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

NODE代理訪問

1. 場景

  • 本地開發(fā),代理訪問,防止跨域(一般通過webpack配置代理即可),特殊情況如攜帶一些自定義的登錄cookie則需要通過自己寫node
  • 作為一種server中間層,單線程異步可以緩解服務器壓力。長鏈接websocket通常使用node搭建

2. 技術框架

  • node - koa2 體量小,輕便易用。
  • 路由koa-router koa配套路由,中間件支持async
  • koa2-request 基于async對 request的封裝,這里本人git上找的,可靠性帶考量,若基于生產環(huán)境建議使用request自行封裝
  • koa-bodyparser 請求參數(shù)解析格式化-中間件

3. 上代碼

3.1 創(chuàng)建應用 app.js

const Koa = require('koa')
const bodyParser = require('koa-bodyparser')
// 路由
const router = require('./router')
const app = new Koa()

app.use(
 bodyParser({
   // 返回的對象是一個鍵值對,當extended為false的時候,鍵值對中的值就為'String'或'Array'形式,為true的時候,則可為任何數(shù)據(jù)類型。
  extended: true 
 })
)

3.2 允許跨域 app.js

app.use(async (ctx, next) => {
 ctx.set('Access-Control-Allow-Origin', '*')
 ctx.set('Access-Control-Allow-Headers', 'content-type')
 ctx.set(
  'Access-Control-Allow-Methods',
  'OPTIONS,GET,HEAD,PUT,POST,DELETE,PATCH'
 )
 await next()
})

3.2 使用路由

// app.js

app.use(router.routes())


// router.js

const Router = require('koa-router')
let koaRequest = require('./httpRequest')
const router = new Router()

router.get('/*', async (ctx, next) => {
 const url = setQuestUrl(ctx.url)
 try {
  let res = await koaRequest(url, 'GET', ctx)
  ctx.body = res
 } catch (err) {
  ctx.body = err
 }
})

router.post('/*', async (ctx, next) => {
 const url = setQuestUrl(ctx.url)
 try {
  let res = await koaRequest(url, 'POST', ctx)
  ctx.body = res
 } catch (err) {
  ctx.body = err
 }
})

function setQuestUrl(url) {
 if (/^\/t/.test(url)) {
  return 'host1'+ url.replace(/^\/t/, '')
 }
 if (/^\/xt/.test(url)) {
  return 'host2' + url.replace(/^\/xt/, '')
 }
}

module.exports = router
  • router.get('/*', async (ctx, next) => {}) koa路由 ‘/*' 為通配符,匹配所有get請求;next方法調用表示進入下一個中間件;
  • ctx請求上下文,ctx.request.body post請求參數(shù)
  • koa的中間件原理 洋蔥圈模型:

const Koa = require('koa2');
const app = new Koa();

// logger
app.use(async (ctx, next) => {
 console.log('第一層洋蔥 - 開始')
 await next();
 const rt = ctx.response.get('X-Response-Time');
 console.log(`${ctx.method} ${ctx.url} - ${rt}`);
 console.log('第一層洋蔥 - 結束')
});

// x-response-time
app.use(async (ctx, next) => {
 console.log('第二層洋蔥 - 開始')
 const start = Date.now();
 await next();
 const ms = Date.now() - start;
 ctx.set('X-Response-Time', `${ms}ms`);
 console.log('第二層洋蔥 - 結束')
});

// response
app.use(async ctx => {
 console.log('第三層洋蔥 - 開始')
 ctx.body = 'Hello World';
 console.log('第三層洋蔥 - 結束')
});

app.listen(8000);


// 輸出

第一層洋蔥 - 開始
第二層洋蔥 - 開始
第三層洋蔥 - 開始

第三層洋蔥 - 結束
第二層洋蔥 - 結束
第一層洋蔥 - 結束

setQuestUrl 此方法主要是將前端訪問的路徑,根據(jù)第一級轉發(fā)到不同的host上

例如: /t -> host1

3.3 轉發(fā)請求 httpRequest.js

本例主要為了代理訪問并攜帶Cookie, const.js 為寫死的要攜帶的cookie

let koa2Req = require('koa2-request')

let constConfig = require('./const')

let iToken = constConfig.iToken

let koaRequest = async function(url, method, ctx) {
 let options = {
  method: method,
  uri: url,
  timeout: 120000,
  body: ctx
   ? {
     ...ctx.request.body
    }
   : null,
  headers: {},
  json: true // Automatically stringifies the body to JSON
 }
 options.headers['Cookie'] = `i-token=${iToken}` //設置cookie
 let res = await koa2Req(options)

 return res.body
}

// node-mon

async function getTestToken() {
 if (!constConfig.iToken) {
  let url = `http://xt.eqxiu.com/tui/app/radar/test/getToken?companyId=${constConfig.companyId}&staffId=${constConfig.staffId}`
  try {
   let res = await koaRequest(url, 'GET')
   iToken = res.obj
   console.log('token已拿到:' + iToken)
  } catch (e) {
   console.log(e)
  }
 }
}

getTestToken()

module.exports = koaRequest

3.4 最后設置端口等

const app = require('./app')
//const createWebsocket = require('./websocket')

const server = require('http').createServer(app.callback())

server.setTimeout(2 * 60 * 1000) //設置超時時間

const { PORT = 3000 } = process.env

server.listen(PORT, () => {
 console.log(`Listening on port ${PORT}`)
})

3.5 本地開發(fā),熱重啟

安裝 nodemon

yarn add nodemon

設置忽略監(jiān)聽

nodemon.josn node項目根目錄下

{
 "ignore": ["node_modules/*"] //忽略node_modules下文件修改的監(jiān)聽
}

package.josn

通過npm run server啟動

{
 "dependencies": {
  "koa": "^2.8.1",
  "koa-bodyparser": "^4.2.1",
  "koa-router": "^7.4.0",
  "koa2-request": "^1.0.4",
  "nodemon": "^1.19.1"
 },
 "scripts": {
  "server": "nodemon index.js"
 }
}

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

相關文章

  • 使用npm發(fā)布Node.JS程序包教程

    使用npm發(fā)布Node.JS程序包教程

    這篇文章主要介紹了使用npm發(fā)布Node.JS程序包教程,本文講解了配置package.json、注冊npm帳號、發(fā)布程序包等內容,需要的朋友可以參考下
    2015-03-03
  • Node.js的文件權限及讀寫flag詳解

    Node.js的文件權限及讀寫flag詳解

    Node.js對文件的讀寫還是相當靈活的,因為自己老是記不住文件或目錄權限的數(shù)值表達和字符表達。所以整理出這篇文章,方便以后查閱,下面來一起看看吧。
    2016-10-10
  • 初識Node.js

    初識Node.js

    本文給大家介紹的是node.js的初體驗,從最簡單的內容開始,慢慢的深入分析node.js。并附上一則很不錯的文章《7天學會nodeJS》更加詳細的向我們展示了node.js的學習步驟。
    2015-03-03
  • 詳解nodejs通過響應回寫的方式渲染頁面資源

    詳解nodejs通過響應回寫的方式渲染頁面資源

    本篇文章主要介紹了詳解nodejs通過響應回寫的方式渲染頁面資源,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • node.js解決客戶端請求數(shù)據(jù)里面中文亂碼的事件方法

    node.js解決客戶端請求數(shù)據(jù)里面中文亂碼的事件方法

    本文主要介紹了node.js解決客戶端請求數(shù)據(jù)里面中文亂碼的事件方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • node.js操作mongodb簡單示例分享

    node.js操作mongodb簡單示例分享

    MongoDB是基于Javascript語言的數(shù)據(jù)庫,存儲格式是JSON,而Node也是基于JavaScript的環(huán)境(庫),所以node和mongoDB的搭配能減少因為數(shù)據(jù)轉換帶來的時間空間開銷。今天我們來看看如何通過node.js來操作MongoliaDB
    2017-05-05
  • 前端Electron新手入門教程詳解

    前端Electron新手入門教程詳解

    這篇文章主要介紹了Electron新手入門教程詳解,首先圍繞Electron框架的關鍵知識點進行詳細講解,然后對DEMO程序進行分析,讓前端開發(fā)人員對使用Electron開發(fā)桌面應用程序有一個初步的了解。,需要的朋友可以參考下
    2019-06-06
  • 手把手教你如何使用nodejs編寫cli命令行

    手把手教你如何使用nodejs編寫cli命令行

    這篇文章主要介紹了手把手教你如何使用nodejs編寫cli命令行,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • 運行Node.js的IIS擴展iisnode安裝配置筆記

    運行Node.js的IIS擴展iisnode安裝配置筆記

    這篇文章主要介紹了運行Node.js的IIS擴展iisnode安裝配置筆記,iisnode的擴展可以把Node.js程序托管到IIS,托管之后也意味著可以使用IIS里面的各種功能,需要的朋友可以參考下
    2015-03-03
  • 使用nodejs爬取前程無憂前端技能排行

    使用nodejs爬取前程無憂前端技能排行

    這篇文章主要介紹了使用nodejs爬前程無憂前端技能排行,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-05-05

最新評論