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

首頁 > 語言 > JavaScript > 正文

詳解一個基于套接字實現長連接的express

2024-05-06 15:41:17
字體:
來源:轉載
供稿:網友

邏輯: 首先把routerUrl目錄下的函數初始化緩存起來,通過Router.request調用緩存起來的函數,這個函數實際上是register.set方法,主要是開始運行函數鏈,通過register.next 運行下一個函數。

函數流 main.js --> Router.request --> register.set --> register.next --> sock.write

main.js

'use strict';const routerUrl = 'router'; // 當前目錄下的router地址const Router = require('./net/Router'); // 初始化路由const net = require('net');const port = '3000';Router.init(routerUrl);const app = sock => {  sock.on('data', function (data) {    try {      Router.request(data, sock);    } catch (error) {      console.log(error)    }  });  sock.on('error', (err) => {    console.log(err)  })  // 為這個socket實例添加一個"close"事件處理函數  sock.on('close', function (data) {    console.log('clone')  })}const server = net.createServer(app);server.listen(port, () => {  console.log(`Startu in env ${process.env.NODE_ENV || 'development'} on port ${port}`);});server.on('error', (err) => {  console.log(err)})

路由加載:

Router.js文件

const fs = require('fs');const _ = require('lodash');var path = require("path");var ROOT_PATH = path.resolve(__dirname);class Router {  constructor() {    this.routeMap = {};  }  /**   * 通過routerUrl來匹配目錄下的文件,加載進來   * @param {*} routerUrl   */  init(routerUrl) {    let files = fs.readdirSync(path.join(ROOT_PATH, `../${routerUrl}`));    return _.reduce(files, (config, file) => {      let svc = require(path.join(ROOT_PATH, `../${routerUrl}/${file}`));      this.routeMap = {        [file.split('.')[0]]: svc.get()      };    }, {})  }  /**   * 通過url匹配加載的router, 其他字段可自定義,url這里的邏輯也可改成配置文件進行配置,類似于protobuf   * @param {*} data {url, body}   * @param {*} sock   */  request(data, sock) {    try {      this.routeMap[result.url.split('/')[1]][result.url.replace(`/${result.url.split('/')[1]}`, '')](data, sock);    } catch (error) {      sock.write(error);    }  }}module.exports = new Router();

中間件:

register.js文件

const Next = require('./next');class Register {  constructor() {    this._init = {};  }  <!-- 初始化router函數,開始運行函數鏈 -->  set(url, ...handlers) {    this._init[url] = async (data, sock) => {      try {        let next = new Next(handlers);        next.run(data, sock);        } catch (error) {        sock.write(error);      }    };  }  <!-- 獲取初始化的router函數 -->  get() {    return this._init;  }}module.exports = new Register();

nest.js文件

class Next {  constructor(stack) {    this.index = 0;    this.stack = stack;    this.data = null;    this.sock = null;  }  <!-- 運行中間件 -->  run(data, sock) {    this.data = data;    this.sock = sock;    this.stack[this.index](data, sock, this.next.bind(this));  }  <!-- 調到下一個中間件,若帶參數就跳到第arguments[0]步 -->  next() {    if (arguments[0] && arguments[0] === +arguments[0] && +arguments[0] < this.stack.length) {      this.index = +arguments[0];      return this.run(data, this.sock);    }    this.index++;    this.run(this.data, this.sock);  }}module.exports = Next;            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 庆阳市| 屏东县| 渝中区| 平乐县| 平顶山市| 瑞安市| 池州市| 榆中县| 比如县| 东乌珠穆沁旗| 桂平市| 双桥区| 罗定市| 凌云县| 德阳市| 莒南县| 鸡东县| 基隆市| 丹寨县| 双辽市| 清徐县| 龙门县| 三亚市| 高密市| 正阳县| 扶风县| 梅州市| 修文县| 宿迁市| 浦县| 宜城市| 宁夏| 广德县| 德兴市| 浪卡子县| 郧西县| 专栏| 新乡市| 区。| 东阳市| 平果县|