出典:Nodeビギナーズブック

レッスンの目的

 HTTPリクエストに応じて行き先を変えるための、routerモジュールを作成。
 HTTPリクエストの中を見て、リクエストURLやGET、POSTパラメータを抽出。

 必要な情報はすべて、コールバック関数onRequest()の第一引数として渡されるrequest オブジェクトから得ることができる。 内容を解釈するためには、Node.jsの追加のモジュール、urlとquerystringが必要。
 urlモジュールが提供するのは、URLの各部分(例えば、リクエストパスやクエリ文字列)を抽出するメソッド。 抽出後、querystringモジュールでリクエストパラメータのクエリ文字列をパースする。

1. 簡単なrouterの作成

server003.js
var http = require("http");
var url = require("url");

function start(route) {
  function onRequest(request, response) {
    var pathname = url.parse(request.url).pathname;
    console.log( pathname + "へのリクエストを受け取りました");
    route(pathname);
    response.writeHead(200, {"Content-Type": "text/plain; charset=utf-8"});
    response.write("世界の皆さんこんにちは\nHello World"); 
    response.end();
  }
  http.createServer(onRequest).listen(8888);
  console.log("サーバー動作開始");
}
exports.start = start;
router003.js
function route(pathname) {
  console.log( pathname + "へのリクエストのルーティング処理を開始しました" );
}

exports.route = route;
index003.js
var server = require("./server003");
var router = require("./router003");
server.start(router.route);
実行
$ node server003
実行結果
pi@raspberrypi:~ $ node index003.js
サーバー動作開始
/へのリクエストを受け取りました
/へのリクエストのルーティング処理を開始しました
リクエスト/favicon.icoを受け取りました
/favicon.icoへのリクエストのルーティング処理を開始しました


2. リクエストハンドラによる応答

requestHandlers004.js
function start() {
  console.log("リクエストハンドラ 'start' が呼ばれました");
  return "Hello Start";
}

function upload() {
  console.log("リクエストハンドラ 'upload' が呼ばれました");
  return "Hello Upload";
}

exports.start = start;
exports.upload = upload;
router004.js
function route(handle, pathname) {
  console.log(pathname + "へのリクエストにとりかかりました" );
  if (typeof handle[pathname] === 'function') {
    return handle[pathname]();
  } else {
    console.log(pathname + "へのリクエストハンドラが見つかりません");
    return "404 Not found";
  }
}
exports.route = route;
server004.js
var http = require("http");
var url = require("url");

function start(route, handle) {
  function onRequest(request, response) {
    var pathname = url.parse(request.url).pathname;
    console.log(pathname + " へのリクエストを受け取りました");
    response.writeHead(200, {"Content-Type": "text/plain; charset=utf-8"});
    var content = route(handle, pathname)
    response.write(content);
    response.end();
  }
  http.createServer(onRequest).listen(8888);
  console.log("サーバー動作開始");
}

exports.start = start;
index004.js
var server = require("./server004");
var router = require("./router004");
var requestHandlers = require("./requestHandlers004");

var handle = {}
handle["/"] = requestHandlers.start;
handle["/start"] = requestHandlers.start;
handle["/upload"] = requestHandlers.upload;

server.start(router.route, handle);
実行結果
pi@raspberrypi:~ $ node index004.js

 サーバーを立ち上げWebブラウザで3つのページを開いてみた
http://raspberrypi.local:8888/upload
http://raspberrypi.local:8888/
http://raspberrypi.local:8888/start
 コンソールログがこちら

サーバー動作開始
/upload へのリクエストを受け取りました
/uploadへのリクエストにとりかかりました
リクエストハンドラ 'upload' が呼ばれました
/ へのリクエストを受け取りました
/へのリクエストにとりかかりました
リクエストハンドラ 'start' が呼ばれました
/start へのリクエストを受け取りました
/startへのリクエストにとりかかりました
リクエストハンドラ 'start' が呼ばれました