之前加入了一個學習筆記本群,通過學習筆記來分享學習成果。也在這里發一份吧。
* 難得第一次發首頁,還不給上。那一些hello world的都能上。好歹是我自己研究過的,太不尊重人了。
當我們在寫web的時候,難免會要使用到cookie,由於node.js有了express這個web框架,我們就可以方便地去建站。在使用express時,經常會使用到cookie-parser這個插件。今天我們來分析一下這個插件。
這個插件通常當作中間件使用,app.use(cookieParser()), 這樣就可以處理每一個請求的cookie。
從名字上看,這就是一個解釋Cookie的工具。通過req.cookies可以取到傳過來的cookie,並把它們轉成對象。下面,我們來深入它的源碼。
首先,我們看index.js
var cookie = require('cookie');
var parse = require('./lib/parse');
這里有2個引用,一個是cookie,一個是cookie-parser這個核心功能。cookie這個模塊,只提供了2個方法,一個是serialize另一個是parse。
serialize方法接收key和val,並序列化。
var hdr = cookie.serialize('foo', 'bar'); // hdr = 'foo=bar';
paser方法把字符串轉成對象
var cookies = cookie.parse('foo=bar; cat=meow; dog=ruff'); // cookies = { foo: 'bar', cat: 'meow', dog: 'ruff' };
再看下面,就是cookie-parser的主函數cookiePaser。
exports = module.exports = function cookieParser(secret, options){
return function cookieParser(req, res, next) { // 從請求中得到req,res對象
if (req.cookies) return next(); // 如果已經有cookie對象,則退出中間件繼續運行
var cookies = req.headers.cookie; // 從headers中取cookie
req.secret = secret; // 如果有傳入secret,則設置到req對象
req.cookies = Object.create(null); // 創建空對象給req.cookies
req.signedCookies = Object.create(null); // 創建空對象給req.signedCookies
// no cookies
if (!cookies) { // 如果沒有從headers得到cookies
return next(); // 退出中間件繼續運行
}
req.cookies = cookie.parse(cookies, options); // 調用cookie的parse方便把cookie字符串轉成cookies對象。
// parse signed cookies
if (secret) { // 如果設置了secret,則使用 parse的2個方法,把cookie簽名。
req.signedCookies = parse.signedCookies(req.cookies, secret);
req.signedCookies = parse.JSONCookies(req.signedCookies);
}
// parse JSON cookies
req.cookies = parse.JSONCookies(req.cookies); // 把req.cookies對象轉化
next();
};
};
看了這個主函數,我們還有一些迷茫,正好就是它的主文件parse.js。我們在下次再看這個文件到底是做什么用的吧。
http://www.cnblogs.com/coolicer/p/4191551.html