1. 程式人生 > >自己開發簡單web伺服器二(Node.js實現)

自己開發簡單web伺服器二(Node.js實現)

Node.js

剛接觸Node.js沒多久,試用了一下,輕輕鬆鬆幾行程式碼就可以實現一個簡單的HTTP伺服器,開發起來的確比其他語言快多了。

Node.js是一個開源的JavaScript庫,可以跨平臺執行在Windows、Linux、Mac上。JS解析庫用的是大名鼎鼎的Google V8引擎(chrome瀏覽器裡使用的),網路處理庫用的是libuv(Windows上試用IOCP實現,Linux上試用epoll實現),由於使用了這些高效能的跨平臺庫,Node.js的效能足夠強悍(PS:當然沒有直接用C\C++效率高)。可以這麼說吧:Node.js = V8 + libuv。

require表示引用需要的庫,建立http伺服器程式時,制定下請求回撥函式onRequest即可在其中處理各種客戶端的請求。

listen用來設定監聽埠,客戶端連線這個埠就可以與伺服器通訊了(HTTP協議建立在TCP協議上,基本的套接字知識不在這裡說明)。

和上一節說的一樣,首先處理請求的型別,request.method就是型別名稱。然後是處理請求的頁面地址,針對不同的request.url返回伺服器不同的資料。/請求圖示favicon.ico時,讀取ico檔案並返回二進位制資料;請求HTML靜態頁面/test.html時,讀取這個檔案返回字串……

這裡直接上程式碼了。

程式碼

var http = require("http");
var fs = require("fs");
var mudUrl = require('url');

server = http.createServer(onRequest);
server.listen(8080);

function onRequest(request, response){
    if (request.method == "GET"){
        if (request.url == '/'){
            response.writeHead(200, {'Content-Type': 'text/plain'});
            response.write("hello node.js");
            response.end();
        }
        else if (request.url == '/favicon.ico'){
            //http://127.0.0.1:8080/
            fs.readFile("server/update.ico", function(err, bytes){
                if (err){
                    console.log(err);
                }
                else{
                    response.writeHead(200, {'Content-Type': 'image/x-icon'});
                    response.write(bytes);
                    response.end();
                }
            });
        }
        else if (request.url == '/test.html'){
             fs.readFile("server/test.htm", function(err, bytes){
                if (err){
                    console.log(err);
                }
                else{
                    response.writeHead(200, {'Content-Type': 'text/html'});
                    response.write(bytes);
                    response.end();
                }
            });
        }
        else if (request.url == '/server/test.jpg'){
            fs.readFile("server/test.jpg", function(err, bytes){
                if (err){
                    console.log(err);
                }
                else{
                    response.writeHead(200, {'Content-Type': 'image/jpeg'});
                    response.write(bytes);
                    response.end();
                }
            });
        }
        else if (request.url.substring(0, 10) == '/interface'){
            var params = mudUrl.parse(request.url, true);
            try{
                var id = params.query['id'];
                var name = params.query['name'];
                var wd = params.query['wd'];
                console.log("id = " + id + " name = " + name + " wd = " + wd);
                var jsonData = {};
                jsonData['code'] = 200;
                jsonData['key'] = "yes";
                var strJson = JSON.stringify(jsonData);
                response.writeHead(200, {'Content-Type': 'text/plain'});
                response.write(strJson);
                response.end();
            }
            catch(error){
                console.log(error);
            }
            //console.log(params);
            //console.log(params.query);
        }
        else{
            response.writeHead(404, {'Content-Type': 'text/html'});
            response.write("<html>\
            <body>\
            <p>can not find the page!<p>\
            </body>\
            </html>");
            response.end();
        }
    }
    else if (request.method == "POST"){
        response.writeHead(200, {'Content-Type': 'text/plain'});
        response.end('Hello World post\n');
    }
}

返回json資料

node.js中json資料的格式化特別簡單,只需要呼叫JSON.stringify就可以把一個json物件轉換成json字串(C\C++需要引用json開源庫來處理)。

var jsonData = {};
                jsonData['code'] = 200;
                jsonData['key'] = "yes";
                var strJson = JSON.stringify(jsonData);


response.writeHead(200, {'Content-Type': 'text/plain'});返回http請求的返回碼和返回資料格式;

response.write(strJson);寫入返回給客戶端的資料流(可以是字串,二進位制等);

response.end();請求返回資料構造完成,可以返回給客戶端了。

除錯node.js

下載微軟的VS Code,開啟JS所在的資料夾,按F5即可除錯,第一次除錯前VS Code會開啟一個檔案launch.json讓你填寫除錯的JS檔案,只需要把下圖位置的檔名換成你的JS檔案的名字即可開始除錯了(我的檔名是server.js)。