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

首頁 > 編程 > JavaScript > 正文

NodeJS學(xué)習(xí)筆記之Connect中間件模塊(一)

2019-11-20 13:18:47
字體:
供稿:網(wǎng)友

希望大家能夠堅(jiān)持看下去我這系列的文章,這也是對(duì)我的最大的鼓勵(lì)與支持,讓我們共同進(jìn)步,以文會(huì)友,相互幫助。好了直接進(jìn)入今天的主題,

什么是“Connect”,中間件又當(dāng)如何理解,帶著問題來看今天的文章。

如何理解 "中間件" ?

我的理解是這樣的,中間件就是類似于一個(gè)過濾器的東西,在客戶端和應(yīng)用程序之間的一個(gè)處理請(qǐng)求和響應(yīng)的的方法。

如果把一個(gè)http處理過程比作是污水處理,中間件就像是一層層的過濾網(wǎng)。每個(gè)中間件在http處理過程中通過改寫request或(和)response的數(shù)據(jù),

狀態(tài),實(shí)現(xiàn)了特定的功能。

什么是 ”Connect“ ?

我們可以把Connec看做一堆中間件的集合。對(duì)于每一次請(qǐng)求,Connect將會(huì)使用中間件層來過濾請(qǐng)求,其中每一個(gè)中間件都可以獲取HTTP請(qǐng)求。

T.J Holowaychuk談到Connect時(shí),他說一共有兩種類型的中間件。其中一種是過濾器:

過濾器處理請(qǐng)求,但是他們并不針對(duì)請(qǐng)求進(jìn)行回應(yīng)(想想服務(wù)器日志)。

第二種類型是供應(yīng)器,它會(huì)針對(duì)請(qǐng)求進(jìn)行回應(yīng),你可以根據(jù)你的需求使用多個(gè)中間件,Http請(qǐng)求將會(huì)通過每一個(gè)中間件直到其中一個(gè)中間件對(duì)請(qǐng)求進(jìn)行回應(yīng)。

二,Connect內(nèi)置中間件介紹

下面列舉出幾個(gè)主要的中間件,并且實(shí)例講述:

(1),cookieParser------cookie解析中間件,解析Cookies的頭通過req.cookies得到cookies。還可以通過req.secret加密cookies。

復(fù)制代碼 代碼如下:

var connect = require('./lib/connect') ;
var app = connect()
.use(connect.cookieParser('secret string'))
.use(function (req,res,next){
    req.cookies.website="hi,i am bigbear !" ;
    res.end(JSON.stringify(req.cookies)) ;
}).listen(8888) ;

(2),session

  描述:會(huì)話管理中間件

  依賴:cookieParser

  參數(shù):options

  options:

    key:Cookies名,默認(rèn)值為connect.sid

    store: session存儲(chǔ)實(shí)例

    secret: session的cookie加密

    cookie: session的cookie配置,默認(rèn)值為{path: ‘/', httpOnly: true, maxAge: null}

    proxy:安全cookie的反向代理,通過x-forwarded-proto實(shí)現(xiàn)

    Cookie option:

    cookie.maxAge: 默認(rèn)值null,表示當(dāng)瀏覽器關(guān)閉后cookie被刪除。

復(fù)制代碼 代碼如下:

 var connect = require('./lib/connect');
 var app = connect()
 .use(connect.logger('dev'))
 .use(connect.cookieParser())
 .use(connect.session({secret: '123', cookie: { maxAge: 60000 }}))
 .use(function (req, res, next) {
     if(req.session.pv){
         res.setHeader('Content-Type', 'text/html');
         res.write('views: ' + req.session.pv);
         res.end();
         req.session.pv++;
     }else{
         req.session.pv = 1;
         res.end('Refresh');
     }
 })
 .listen(8888);

  隨著客戶端不斷刷新頁面 "PV" 會(huì)不斷增加,服務(wù)器端 “Session” 維護(hù)數(shù)量 。

(3),bodyParser------請(qǐng)求內(nèi)容解析中間件,支持多種類型application/json,application/x-www-form-urlencoded, multipart/form-data。  

復(fù)制代碼 代碼如下:

 var connect = require('connect');
 var app = connect()
     .use(connect.bodyParser())
     .use(function(req, res) {
         res.end('req.body=>' + JSON.stringify(req.body));
     })
 .listen(8888);

 三,再來個(gè)對(duì)比實(shí)例,看看使用中間件的好處。

復(fù)制代碼 代碼如下:

 /*
  * 使用connect實(shí)現(xiàn)的靜態(tài)文件處理
  */
 var connect = require('connect');
 connect(connect.static(__dirname + '/public')).listen(//監(jiān)聽
     8888,
     function() {
         console.log('Connect started on port 8888');
     }
 );
 /*
  * 使用node原生api實(shí)現(xiàn)
  */
 var http = require('http');
 http.createServer(
     function(req, res) {
         var url = require('url');
         var fs = require('fs');
         var pathname = __dirname + '/public' + url.parse(req.url).pathname;
         //讀取本地文件
         fs.readFile(
             pathname,
             function(err, data) {
                 //異常處理
                 if (err) {
                     res.writeHead(500);
                     res.end('500');
                 }
                 else {
                     res.end(data);
                 }
             }
         );
     }
 ).listen(//監(jiān)聽
     8888,
     function() {
         console.log('Http Server started on port 8888');
     }
 );

盡管node原生api已經(jīng)花費(fèi)這么些行代碼,但其實(shí)仍然留下一個(gè)簡(jiǎn)單靜態(tài)文件服務(wù)器的諸多方面未經(jīng)處理,

比如:404等異常未處理、沒有基本的文件路徑安全驗(yàn)證(實(shí)際上我們可以訪問到整個(gè)os文件系統(tǒng))、全局異常處理等等;

與此同時(shí)connect已經(jīng)將這些問題都處理好了。

四,總結(jié)一下

 (1),理解中間件流式處理。

復(fù)制代碼 代碼如下:

 var app = connect();
 app.use(connect.staticCache());
 app.use(connect.static(__dirname + '/public'));
 app.use(connect.cookieParser());
 app.use(connect.session());
 app.use(connect.query());
 app.use(connect.bodyParser());
 app.use(connect.csrf());
 app.use(function (req, res, next) {
   // 中間件
 });
 app.listen(8888);

(2),原生實(shí)現(xiàn)方式與中間件實(shí)現(xiàn)之間的差異化。

(3),通過上述的幾個(gè)中間件例子,理解用途和使用場(chǎng)景并且參考相關(guān)文檔掌握其余中間件的基本使用。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 双流县| 普定县| 荣成市| 翁源县| 清流县| 龙岩市| 东乡| 乌海市| 通州市| 时尚| 盐池县| 明光市| 平乡县| 涞水县| 怀远县| 新闻| 泸定县| 邢台县| 德州市| 新宁县| 齐齐哈尔市| 富蕴县| 团风县| 大埔区| 湖口县| 和林格尔县| 将乐县| 隆化县| 嘉祥县| 榆社县| 莲花县| 庆阳市| 略阳县| 濮阳县| 贵溪市| 巴东县| 龙川县| 台北市| 昭平县| 石泉县| 洛川县|