以前加入了一個學習筆記本羣,經過學習筆記來分享學習成果。也在這裏發一份吧。html
* 可貴第一次發首頁,還不給上。那一些hello world的都能上。好歹是我本身研究過的,太不尊重人了。node
當咱們在寫web的時候,不免會要使用到cookie,因爲node.js有了express這個web框架,咱們就能夠方便地去建站。在使用express時,常常會使用到cookie-parser這個插件。今天咱們來分析一下這個插件。git
這個插件一般看成中間件使用,app.use(cookieParser()), 這樣就能夠處理每個請求的cookie。
從名字上看,這就是一個解釋Cookie的工具。經過req.cookies能夠取到傳過來的cookie,並把它們轉成對象。下面,咱們來深刻它的源碼。
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