1.1 请求方法的判断

var http = require('http');

var server = http.createServer(function(request,response){

switch(request.method){

case 'POST':

update(request,response);

break;

case 'DELETE':

remove(request,response);

break;

case 'PUT':

create(request,response);

break;

case 'GET':

default:

get(request,response);

}

});

server.listen(8000,'127.0.0.1');

1.2 路径解析

var http = require('http');

var url = require('url');

var server = http.createServer(function(request,response){

var pathname = url.parse(request.url).pathname;

var paths = pathname.split('/');

var controler = paths[1] || 'index';

var action = paths[2] || 'action';

var args = paths.slice(3);

if(handles[controler]&&handles[controler][action]){

handles[controler][action].apply(null,[request,response].concat(args));

}else{

response.writeHead(500);

response.end('error');

}

});

server.listen(8000,'127.0.0.1');

var handles = {};

handles.index = {};

handles.index.index = function(request,response){

response.writeHead(200);

response.end('success');

}

1.3 查询字符串

var http = require('http');

var url = require('url');

var server = http.createServer(function(request,response){

request.query = url.parse(request.url,true).query;

handle(request,response);

});

server.listen(8000,'127.0.0.1');

var handle = function(request,response){

}

1.4 Cookie

var parseCookie = function(cookie){

var cookies = {};

if(!cookie){

return cookies;

}

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;

}

var serializeCookie = function(name,value,options){

var pairs = [name+'='+encodeURI(value)];

options = options || {};

if(options.maxAge){

pairs.push('Max-Age='+options.maxAge);

}

if(options.domain){

pairs.push('Domain='+options.domain);

}

if(options.path){

pairs.push('Path='+options.path);

}

if(options.expires){

pairs.push('Expires='+options.expires.toUTCString());

}

if(options.httpOnly){

pairs.push('HttpOnly');

}

if(options.secure){

pairs.push('Secure');

}

return pairs.join('; ');

}

var http = require('http');

var url = require('url');

var server = http.createServer(function(request,response){

request.cookies = parseCookie(request.headers.cookie);

handle(request,response);

});

server.listen(8000,'127.0.0.1');

var handle = function(request,response){

console.log(request.cookies);

}

1.5 Session

var sessions = {};

var key = 'session_id';

var EXPIRES = 20*60*1000;

var generate = function(){

var session = {};

session.id = (new Date()).getTime()+Math.random();

session.cookie = {

expire:(new Date()).getTime()+EXPIRES

}

sessions[session.id] = session;

return session;

}

var http = require('http');

var url = require('url');

Function.prototype.before = function(beforefn){

var _self = this;

return function(){

beforefn.apply(this,arguments);

return _self.apply(this,arguments);

}

}

var server = http.createServer(function(request,response){

request.cookies = parseCookie(request.headers.cookie);

var id = request.cookies[key];

if(!id){

request.session = generate();

}else{

var session = sessions[id];

if(session){

if(session.cookie.expire > (new Date()).getTime()){

session.cookie.expire = (new Date()).getTime()+EXPIRES;

request.session = session;

}else{

delete sessions[id];

request.session = generate();

}

}else{

request.session = generate();

}

}

response.writeHead.before(function(){

var cookies = response.getHeader('Set-Cookie');

var session = serializeCookie(key,request.session.id);

cookies = Array.isArray(cookies)?cookies.concat(session):[cookies,session];

response.setHeader('Set-Cookie',cookies);

});

handle(request,response);

});

server.listen(8000,'127.0.0.1');

var handle = function(request,response){

console.log(request.cookies);

response.writeHead(200);

response.end('ok');

}

1.6 数据上传

var http = require('http');

var url = require('url');

var querystring = require('querystring');

var xml2js= require('xml2js');

var formidable= require('formidable');

var hasBody = function(request){

return 'transfer-encoding' in request.headers || 'content-length' in request.headers;

}

var mime = function(request){

var str = request.headers['content-type'] || '';

return str;

}

var server = http.createServer(function(request,response){

if(hasBody(request)){

var buffers = [];

request.on('data',function(chunk){

buffers.push(chunk);

});

request.on('end',function(){

request.rawBody = Buffer.concat(buffers).toString();

handle(request,response);

});

}

else{

handle(request,response);

}

});

server.listen(8000,'127.0.0.1');

var handle = function(request,response){

//表单

if(mime(request) == 'application/x-www-form-urlencoded'){

request.body = querystring.parse(request.rawBody);

handle(request,response);

}else if(mime(request) == 'application/json'){

request.body = JSON.parse(request.rawBody);

handle(request,response);

}else if(mime(request) == 'application/xml'){

xml2js.parseString(request.rawBody,function(err,xml){

request.body = xml;

handle(request,response);

});

}else if(mime(request) == 'multipart/form-data'){

var form = new formidable.IncomingForm();

form.parse(request,function(err,fields,files){

request.body = fields;

request.files = files;

handle(request,response);

});

}else{

console.log('ok');

}

}

1.7 路由解析

var pathRegexp = function(path){

var keys = [];

path = path.concat(strict ?'':'/?')

.replace('/\/\(\g','(?:/')

.replace('/(\/)?(\.)?:(\w+)(?:(\(.*?\)))?(\?)?(\*)?/g',function(_,slash,format,key,capture,optional,star){

keys.push(key);

slash = slash || '';

return ''

+(optional?'':slash)

+'(?:'

+(optional?slash:'')

+(format||'')+(capture || (format && '([^/.]+?)' || '([^/+?])')) +')'

+(optional || '')

+(star?'(/*)?':'');

})

.replace('/([\/.])/g','\\$1')

.replace('/\*/g','(.*)');

return {

keys:keys,

regexp: new RegExp('^'+path+'$')

};

}

var routes = {'all':[]};

var app={};

app.use = function(path){

var handle;

if(typeof path === 'string'){

handle = {

path:pathRegexp(path),

stack:Array.prototype.slice.call(arguments,1)

}

}else{

handle = {

path:pathRegexp('/'),

stack:Array.prototype.slice.call(arguments,0)

}

}

routes.all.push(handle);

}

['get','put','delete','post'].forEach(function(method){

routes[method] = [];

app[method] = function(path){

var handle = {

path:pathRegexp(path),

stack:Array.prototype.slice.call(arguments,1)

}

routes[method].push(handle);

}

});

var querystring = function(request,response,next){

try {

request.query = url.parse(request.url,true).query;

next();

} catch (err) {

next(err);

}

}

var cookie = function(request,response,next){

var cookie = request.headers.cookie;

var cookies = {};

if(cookie){

var list = cookie.split(';');

for(var i=0;i<list.length;i++){

var pair = list[i].split('=');

cookies[pair[0].trim()] = pair[1];

}

}

request.cookies = cookies;

next();

}

var match = function(pathname,routes){

var stacks = [];

for(var i=0;i<routes.length;i++){

var route = routes[i];

var reg = route.path.regexp;

var matched = reg.exec(pathname);

if(matched){

stacks = stacks.concat(route.stack);

}

}

return stacks;

}

var handle404 = function(request,response){

console.log(404)

}

var handle500 = function(err,request,response,stacks){

console.log(500)

}

var handle = function(request,response,stacks){

var next = function(err){

if(err){

return handle500(err,request,response,stacks)

}

var middleware = stacks.shift();

if(middleware){

try {

middleware(request,response,next);

} catch (err) {

next(err);

}

}

}

next();

}

var server = http.createServer(function(request,response){

var pathname = url.parse(request.url).pathname;

var method = request.method.toLowerCase();

var stacks = match(pathname,routes.all);

if(routes.hasOwnPerperty(method)){

stacks.concat(match(pathname,routes[method]));

}

if(stacks.length){

handle(request,response,stacks);

}else{

handle404(request,response)

}

});

server.listen(8000,'127.0.0.1');

构建web应用示例的更多相关文章

  1. Node.js高级编程读书笔记 - 4 构建Web应用程序

    Outline 5 构建Web应用程序 5.1 构建和使用HTTP中间件 5.2 用Express.js创建Web应用程序 5.3 使用Socket.IO创建通用的实时Web应用程序 5 构建Web应 ...

  2. 高效构建Web应用 教你玩转Play框架 http://www.anool.net/?p=577

    Play 框架是一个完整的Web应用开发框架,覆盖了Web应用开发的各个方面.Play 框架在设计的时候借鉴了流行的 Ruby on Rails 和 Grails 等框架,又有自己独有的优势.使用 P ...

  3. threejs构建web三维视图入门教程

    本文是一篇简单的webGL+threejs构建web三维视图的入门教程,你可以了解到利用threejs创建简单的三维图形,并且控制图形运动.若有不足,欢迎指出. 本文使用的框架是three.js gi ...

  4. 实战案例--Grunt构建Web程序

    GruntJS构建Web程序.使用Gruntjs来搭建一个前端项目,然后使用grunt合并,压缩JS文件,熟练了node.js安装和grunt.js安装后,接下来来实战一个案例,案例是根据snandy ...

  5. 使用Vert.x构建Web服务器和消息系统

    如果你对Node.js感兴趣,Vert.x可能是你的下一个大事件:一个建立在JVM上一个类似的架构企业制度. 这一部分介绍Vert.x是通过两个动手的例子(基于Vert.x 2.0). 当Node.j ...

  6. 用 Python 构建 web 应用

    用 Python 构建 web 应用 如果说仅仅要用 Python 构建 web 应用,可以将 socket 连接.HTTP 原始请求和响应格式等涉及网络基础的东西交给现成的库来实现,只需要专注于 w ...

  7. NodeJs+http+fs+request+cheerio 采集,保存数据,并在网页上展示(构建web服务器)

    目的: 数据采集 写入本地文件备份 构建web服务器 将文件读取到网页中进行展示 目录结构: package.json文件中的内容与上一篇一样:NodeJs+Request+Cheerio 采集数据 ...

  8. 使用EXtjs6.2构建web项目

    一.项目简介 众所周知ext是一款非常强大的表格控件,尤其是里边的grid为用户提供了非常多的功能,现在主流的还是用extjs4.0-4.2,但是更高一点的版本更加符合人的审美要求.因此,在今天咱们构 ...

  9. 《深入浅出Node.js》第8章 构建Web应用

    @by Ruth92(转载请注明出处) 第8章 构建Web应用 一.基础功能 请求方法:GET.POST.HEAD.DELETE.PUT.CONNECT GET /path?foo=bar HTTP/ ...

随机推荐

  1. JQ实现右下角scrollTop()事件

    废话不多说,先贴代码 <script> $(document).ready(function(){ $("#id").hide(); $(function(){ // ...

  2. 要让div中的float不会自动显示到下一行来?

    使用 高度 + hidden: 要尝试 恰当的 高度, 设置合适的 div的 height: ... 要让 float的 "最直接的" "亲生的 " " ...

  3. fedora各个版本的下载地址archive

    archive: ['a:kaiv] she went to the city archive this morning. ==================== === fedora 的下载地址是 ...

  4. dwz 在dialog里打开dialog

    需要在打开dialog里再弹出一个dialog的话,需要在打开第一个dialog的地方指定rel,这样就可以弹出第二个dialog而不是替换掉第一个dialog <a class="a ...

  5. "A transport-level error has occurred when sending the request to the server,指定的网络名不在可用"的解决办法

    项目在外网服务器上运行的时候,遇到一个异常:"A transport-level error has occurred when sending the request to the ser ...

  6. springmvc之默认错误页面跳转

    在做一个项目的时候,为了界面美观及用户体验,我们往往会设计自己的错误跳转页面,而不是直接展示给用户一堆错误码,为此我们需要配置自己的错误跳转页面. 1.项目结构 2.web.xml <!DOCT ...

  7. PHP Closure类Bind与BindTo方法

    Closure类为闭包类,PHP中闭包都是Closure的实例: 1 $func = function(){}; 2 var_dump($func instanceof Closure); 输出 bo ...

  8. MySQL Python教程(1)

    首先对于数据库的基本操作要有一定基础,其次了解Python的基础语法. 建议先阅读MysqL中文教程http://doc.mysql.cn/mysql5/refman-5.1-zh.html-chap ...

  9. [Asp.net MVC]Asp.net MVC5系列——添加模型

    目录 概述 添加模型 总结 系列文章 [Asp.net MVC]Asp.net MVC5系列——第一个项目 [Asp.net MVC]Asp.net MVC5系列——添加视图 概述 在本节中我们将追加 ...

  10. BZOJ3083——遥远的国度

    1.题目大意:三个操作,换根,修改树上的某条路径,查询一个子树的最小值 2.分析:这个其实还是挺好做的,修改树上的某条路径,裸树剖,查询子树的最小值,这个是树剖满足dfs序 那么就是换根了,对吧,其实 ...