var http = require('http');
var url = require('url');
var querystring = require('querystring');
// 解析cookie
var parseCookie = function(cookie) {
var cookies = {};
if (!cookie) {
return cookie;
}
var list = cookie.split(';');
for (var i = 0; i < list.length; i++) {
var pair = list[i].split('=');
cookies[pair[0].trim()] = pair[1];
}
return cookies;
};
// cookie 序列化
// cookie 格式:name=value; Path=/; Expires=Sun, 23-Apr-23 09:01:35 GMT; Domain=.domain.com;
var serialize = function (name, val, opt) {
var pairs = [name + '=' + val];
opt = opt || {};
if (opt.maxAge) pairs.push('Max-Age=' + opt.maxAge);
if (opt.domain) pairs.push('Domain=' + opt.domain);
if (opt.path) pairs.push('Path=' + opt.path);
if (opt.expires) pairs.push('Expires=' + opt.exppires.toUTCString());
if (opt.httpOnly) pairs.push('HttpOnly');
if (opt.secure) pairs.push('Secure');
return pairs.join(';');
}
// 句柄判断是否含有cookie
var handle = function(req, res) {
// res.writeHead(200);
if (!req.cookies.isVisit) {
res.setHeader('Set-Cookie', serialize('isVisit','1'));
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Welcome to visit CJS \'s blog first time\n');
} else {
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Hello, my old friend\n');
}
};
//
//
// 服务器在第一登录成功后,会写一个session保存在数据库或者文件里,这个session名字可以是一个随机的数字
// 然后往浏览器写这个数字作为cookie的值
//
// 浏览器每次都会把cookie一起发给服务器,会在reqHeader里
//
// 去session列表里检查是否有这个cookie值 命名的session文件,有的话则不用登录
//
// 这个里面就存在风险了,所以公共场合不用勾选保存登录
http.createServer(
function (req, res){
req.cookies = parseCookie(req.headers.cookie);
handle(req, res);
}
)
.listen(1337, '127.0.0.1');
console.log('Server running at [url]http://127.0.0.1:1337/'[/url]);
var url = require('url');
var querystring = require('querystring');
// 解析cookie
var parseCookie = function(cookie) {
var cookies = {};
if (!cookie) {
return cookie;
}
var list = cookie.split(';');
for (var i = 0; i < list.length; i++) {
var pair = list[i].split('=');
cookies[pair[0].trim()] = pair[1];
}
return cookies;
};
// cookie 序列化
// cookie 格式:name=value; Path=/; Expires=Sun, 23-Apr-23 09:01:35 GMT; Domain=.domain.com;
var serialize = function (name, val, opt) {
var pairs = [name + '=' + val];
opt = opt || {};
if (opt.maxAge) pairs.push('Max-Age=' + opt.maxAge);
if (opt.domain) pairs.push('Domain=' + opt.domain);
if (opt.path) pairs.push('Path=' + opt.path);
if (opt.expires) pairs.push('Expires=' + opt.exppires.toUTCString());
if (opt.httpOnly) pairs.push('HttpOnly');
if (opt.secure) pairs.push('Secure');
return pairs.join(';');
}
// 句柄判断是否含有cookie
var handle = function(req, res) {
// res.writeHead(200);
if (!req.cookies.isVisit) {
res.setHeader('Set-Cookie', serialize('isVisit','1'));
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Welcome to visit CJS \'s blog first time\n');
} else {
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Hello, my old friend\n');
}
};
//
//
// 服务器在第一登录成功后,会写一个session保存在数据库或者文件里,这个session名字可以是一个随机的数字
// 然后往浏览器写这个数字作为cookie的值
//
// 浏览器每次都会把cookie一起发给服务器,会在reqHeader里
//
// 去session列表里检查是否有这个cookie值 命名的session文件,有的话则不用登录
//
// 这个里面就存在风险了,所以公共场合不用勾选保存登录
http.createServer(
function (req, res){
req.cookies = parseCookie(req.headers.cookie);
handle(req, res);
}
)
.listen(1337, '127.0.0.1');
console.log('Server running at [url]http://127.0.0.1:1337/'[/url]);