自己开发简单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("\
            \
            

can not find the page!

\ \ "); 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)。

自己开发简单web服务器二(Node.js实现)_第1张图片




你可能感兴趣的:(前端,开源)