<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        淺談express 中間件機制及實現原理

        來源:懂視網 責編:小采 時間:2020-11-27 22:31:19
        文檔

        淺談express 中間件機制及實現原理

        淺談express 中間件機制及實現原理:簡介 中間件機制可以讓我們在一個給定的流程中添加一個處理步驟,從而對這個流程的輸入或者輸出產生影響,或者產生一些中作用、狀態,或者攔截這個流程。中間件機制和tomcat的過濾器類似,這兩者都屬于責任鏈模式的具體實現。 express 中間件使用案例
        推薦度:
        導讀淺談express 中間件機制及實現原理:簡介 中間件機制可以讓我們在一個給定的流程中添加一個處理步驟,從而對這個流程的輸入或者輸出產生影響,或者產生一些中作用、狀態,或者攔截這個流程。中間件機制和tomcat的過濾器類似,這兩者都屬于責任鏈模式的具體實現。 express 中間件使用案例

        簡介

        中間件機制可以讓我們在一個給定的流程中添加一個處理步驟,從而對這個流程的輸入或者輸出產生影響,或者產生一些中作用、狀態,或者攔截這個流程。中間件機制和tomcat的過濾器類似,這兩者都屬于責任鏈模式的具體實現。

        express 中間件使用案例

        let express = require('express')
        let app = express()
        //解析request 的body
        app.use(bodyParser.json())
        //解析 cookie
        app.use(cookieParser())
        //攔截
        app.get('/hello', function (req, res) {
         res.send('Hello World!');
        });
        

        模擬中間件機制并且模擬實現解析request的中間件

        首先模擬一個request

        request = { //模擬的request
         requestLine: 'POST /iven_ HTTP/1.1',
         headers: 'Host:www.baidu.com\r\nCookie:BAIDUID=E063E9B2690116090FE24E01ACDDF4AD:FG=1;BD_HOME=0',
         requestBody: 'key1=value1&key2=value2&key3=value3',
        }

        一個http請求分為請求行、請求頭、和請求體,這三者之間通過\r\n\r\n即一個空行來分割,這里假設已經將這三者分開,requestLine(請求行)中有方法類型,請求url,http版本號,這三者通過空格來區分,headers(請求頭)中的各部分通過\r\n來分割,requestBody(請求體)中通過 & 來區分參數

        模擬中間件機制

        約定 中間件一定是一個函數并且接受 request, response, next三個參數

        function App() {
         if (!(this instanceof App))
         return new App();
         this.init();
        }
        App.prototype = {
         constructor: App,
         init: function() {
         this.request = { //模擬的request
         requestLine: 'POST /iven_ HTTP/1.1',
         headers: 'Host:www.baidu.com\r\nCookie:BAIDUID=E063E9B2690116090FE24E01ACDDF4AD:FG=1;BD_HOME=0',
         requestBody: 'key1=value1&key2=value2&key3=value3',
         };
         this.response = {}; //模擬的response
         this.chain = []; //存放中間件的一個數組
         this.index = 0; //當前執行的中間件在chain中的位置
         },
         use: function(handle) { //這里默認 handle 是函數,并且這里不做判斷
         this.chain.push(handle);
         },
         next: function() { //當調用next時執行index所指向的中間件
         if (this.index >= this.chain.length)
         return;
         let middleware = this.chain[this.index];
         this.index++;
         middleware(this.request, this.response, this.next.bind(this));
         },
        }
        

        對 request 處理的中間件

         function lineParser(req, res, next) {
         let items = req.requestLine.split(' ');
         req.methond = items[0];
         req.url = items[1];
         req.version = items[2];
         next(); //執行下一個中間件
         }
        
        function headersParser(req, res, next) {
         let items = req.headers.split('\r\n');
         let header = {}
         for(let i in items) {
         let item = items[i].split(':');
         let key = item[0];
         let value = item[1];
         header[key] = value;
         }
         req.header = header;
         next(); //執行下一個中間件
        }
        
        function bodyParser(req, res, next) {
         let bodyStr = req.requestBody;
         let body = {};
         let items = bodyStr.split('&');
         for(let i in items) {
         let item = items[i].split('=');
         let key = item[0];
         let value = item[1];
         body[key] = value;
         }
         req.body = body;
         next(); //執行下一個中間件
        }
        
        function middleware3(req, res, next) {
         console.log('url: '+req.url);
         console.log('methond: '+req.methond);
         console.log('version: '+req.version);
         console.log(req.body);
         console.log(req.header);
         next(); //執行下一個中間件
        }
        
        

        測試代碼

        let app = App();
        app.use(lineParser);
        app.use(headersParser);
        app.use(bodyParser);
        app.use(middleware3);
        app.next();
        

        整體代碼

        function App() {
         if (!(this instanceof App))
         return new App();
         this.init();
        }
        App.prototype = {
         constructor: App,
         init: function() {
         this.request = { //模擬的request
         requestLine: 'POST /iven_ HTTP/1.1',
         headers: 'Host:www.baidu.com\r\nCookie:BAIDUID=E063E9B2690116090FE24E01ACDDF4AD:FG=1;BD_HOME=0',
         requestBody: 'key1=value1&key2=value2&key3=value3',
         };
         this.response = {}; //模擬的response
         this.chain = []; //存放中間件的一個數組
         this.index = 0; //當前執行的中間件在chain中的位置
         },
         use: function(handle) { //這里默認 handle 是函數,并且這里不做判斷
         this.chain.push(handle);
         },
         next: function() { //當調用next時執行index所指向的中間件
         if (this.index >= this.chain.length)
         return;
         let middleware = this.chain[this.index];
         this.index++;
         middleware(this.request, this.response, this.next.bind(this));
         },
        }
        function lineParser(req, res, next) {
         let items = req.requestLine.split(' ');
         req.methond = items[0];
         req.url = items[1];
         req.version = items[2];
         next(); //執行下一個中間件
         }
        
        function headersParser(req, res, next) {
         let items = req.headers.split('\r\n');
         let header = {}
         for(let i in items) {
         let item = items[i].split(':');
         let key = item[0];
         let value = item[1];
         header[key] = value;
         }
         req.header = header;
         next(); //執行下一個中間件
        }
        
        function bodyParser(req, res, next) {
         let bodyStr = req.requestBody;
         let body = {};
         let items = bodyStr.split('&');
         for(let i in items) {
         let item = items[i].split('=');
         let key = item[0];
         let value = item[1];
         body[key] = value;
         }
         req.body = body;
         next(); //執行下一個中間件
        }
        
        function middleware3(req, res, next) {
         console.log('url: '+req.url);
         console.log('methond: '+req.methond);
         console.log('version: '+req.version);
         console.log(req.body);
         console.log(req.header);
         next(); //執行下一個中間件
        }
        let app = App();
        app.use(lineParser);
        app.use(headersParser);
        app.use(bodyParser);
        app.use(middleware3);
        app.next();
        
        

        運行結果

        將以上整體代碼運行后將打印以下信息

        url: /iven_
        methond: POST
        version: HTTP/1.1
        {key1: "value1", key2: "value2", key3: "value3"}
        {Host: "www.baidu.com", Cookie: "BAIDUID=E063E9B2690116090FE24E01ACDDF4AD"}

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        淺談express 中間件機制及實現原理

        淺談express 中間件機制及實現原理:簡介 中間件機制可以讓我們在一個給定的流程中添加一個處理步驟,從而對這個流程的輸入或者輸出產生影響,或者產生一些中作用、狀態,或者攔截這個流程。中間件機制和tomcat的過濾器類似,這兩者都屬于責任鏈模式的具體實現。 express 中間件使用案例
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 国产精品亚洲精品日韩动图| 久久国产精品免费一区二区三区| 久久精品国产亚洲AV香蕉| 四虎成人精品国产永久免费无码| 国产va免费精品| 全部免费毛片在线| 国产精品亚洲天堂| 免费一级黄色毛片| 国产精品免费αv视频| 在线观看亚洲天天一三视| 亚洲人成毛片线播放| 久久99国产综合精品免费| 国产成人精品久久亚洲高清不卡 | 午夜亚洲乱码伦小说区69堂| 国产色爽女小说免费看| 免费国产va视频永久在线观看| 免费99热在线观看| 韩国免费a级作爱片无码| 成人性生交大片免费看无遮挡| avtt天堂网手机版亚洲| 国产小视频在线免费| 性生大片视频免费观看一级| 亚洲中文字幕日产乱码高清app | 国产精品美女午夜爽爽爽免费| 亚洲乱码在线观看| 久久久久久国产精品免费免费男同| 亚洲AV综合色区无码另类小说| 99re在线免费视频| 亚洲kkk4444在线观看| 国产大片免费观看中文字幕| 国产JIZZ中国JIZZ免费看| 亚洲成a人片在线观看中文动漫| 最近免费最新高清中文字幕韩国| 亚洲www在线观看| 免费一级特黄特色大片在线观看| 在线免费视频你懂的| 亚洲国产成人无码av在线播放| 韩国二级毛片免费播放| 亚洲AV综合色区无码二区爱AV| 日本特黄a级高清免费大片| 国产精品美女免费视频观看|