希望大家能夠堅(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。
(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被刪除。
隨著客戶端不斷刷新頁面 "PV" 會(huì)不斷增加,服務(wù)器端 “Session” 維護(hù)數(shù)量 。
(3),bodyParser------請(qǐng)求內(nèi)容解析中間件,支持多種類型application/json,application/x-www-form-urlencoded, multipart/form-data。
三,再來個(gè)對(duì)比實(shí)例,看看使用中間件的好處。
盡管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),理解中間件流式處理。

(2),原生實(shí)現(xiàn)方式與中間件實(shí)現(xiàn)之間的差異化。
(3),通過上述的幾個(gè)中間件例子,理解用途和使用場(chǎng)景并且參考相關(guān)文檔掌握其余中間件的基本使用。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注