nodejs實現一個簡單的 HTTP靜態文件服務器(一)


1.首先我們來實現一個簡單的HTTP服務器

var http = require("http");
var server = http.createServer(function(req, res){
    res.writeHead(200, {'Content-Type' : 'text/html;charset=utf8'});
    res.write('<div style="font-size:24px;color:red">我們的一個簡單的服務器</div>');
});
server.listen('9090', '127.0.0.1');

上面的程序運行結果為:

2.我們獲取請求的url

var http = require("http");
var url = require("url");
var server = http.createServer(function(req, res){
    var req_path = url.parse(req.url).path;
    var str = '<div style="font-size:24px;color:red">我們的請求路徑為:'+req_path+'</div>';
    res.writeHead(200, {'Content-Type' : 'text/html;charset=utf8'});
    res.write(str);
});
server.listen('9090', '127.0.0.1');

上面的程序的運行結果為:

3.以當前文件所在的目錄為網站的根目錄,根據請求的url,將對應的文件返回給瀏覽器;若url表示的文件夾則將此文件夾下的文件名輸出。

var http = require("http");
var url = require("url");
var fs = require("fs");
var server = http.createServer(function(req, res){
    var req_path = url.parse(req.url).path;
    var filepath = __dirname + req_path;
    
    fs.exists(filepath, function(exists){
        if(exists){
            fs.stat(filepath, function(err, stats){
                if(err){
                    res.writeHead(500, {'Content-Type' : 'text/html;charset=utf8'});
                    res.end('<div styel="color:black;font-size:22px;">server error</div>');
                }else{
                    if(stats.isFile()){
                        var file = fs.createReadStream(filepath);
                        res.writeHead(200, {'Content-Type' : 'text/html;charset=utf8'});
                        file.pipe(res);
                    }else{
                        fs.readdir(filepath, function(err, files){
                            var str = '';
                            for(var i in files){
                                str += files[i] + '<br/>';
                            }
                            res.writeHead(200, {'Content-Type' : 'text/html;charset=utf8'});
                            res.write(str);
                        });
                    }
                }
            });
        }else{
            res.writeHead(404, {'Content-Type' : 'text/html;charset=utf8'});
            res.end('<div styel="color:black;font-size:22px;">404 not found</div>');
        }
    });
});
server.listen('9090', '127.0.0.1');

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM