forked from alberto-bottarini/httpdispatcher
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME
48 lines (36 loc) · 1.3 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
httpdispatcher - basic dispatcher for node.js
=======
httpdispatcher is a simple class allows developer to have a clear dispatcher for dynamic pages and static resources.
Classes http.ServerRequest and http.ServerResponse earns new params property containing a map of received HTTP parameters.
Using httpdispatcher is pretty simple:
var dispatcher = require('./httpdispatcher');
dispatcher.setStatic('resources');
dispatcher.onGet("/page1", function(req, res) {
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Page One');
});
dispatcher.onPost("/page2", function(req, res) {
res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Page Two');
});
dispatcher.beforeFilter(/\//, function(req, res, chain) { //any url
console.log("Before filter");
chain.next(req, res, chain);
});
dispatcher.afterFilter(/\//, function(req, res) { //any url
console.log("After filter");
chain.next(req, res, chain);
});
dispatcher.onError(function(req, res) {
res.writeHead(404);
});
http.createServer(function (req, res) {
dispatcher.dispatch(req, res);
}).listen(1337, '127.0.0.1');
/*
GET /page1 => 'Page One'
POST /page2 => 'Page Two'
GET /page3 => 404
GET /resources/images-that-exists.png => Image resource
GET /resources/images-that-does-not-exists.png => 404
*/