国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Nodejs 搭建簡單的Web服務器詳解及實例

2019-11-19 18:45:44
字體:
來源:轉載
供稿:網友

使用 Nodejs 搭建簡單的Web服務器

使用Nodejs搭建Web服務器是學習Node.js比較全面的入門教程,因為要完成一個簡單的Web服務器,你需要學習Nodejs中幾個比較重要的模塊,比如:http協議模塊、文件系統、url解析模塊、路徑解析模塊、以及301重定向問題,下面我們就簡單講一下如何來搭建一個簡單的Web服務器。

作為一個Web服務器應具備以下幾個功能:

1、能顯示以.html/.htm結尾的Web頁面

2、能直接打開以.js/.css/.json/.text結尾的文件內容

3、顯示圖片資源

4、自動下載以.apk/.docx/.zip結尾的文件

5、形如http://xxx.com/a/b/ , 則查找b目錄下是否有index.html,如果有就顯示,如果沒有就列出該目錄下的所有文件及文件夾,并可以進一步訪問。

6、形如http://xxx.com/a/b,  則作301重定向到http://xxx.com/a/b/ , 這樣可以解決內部資源引用錯位的問題。

 引入需要用到的幾個模塊:

//http協議模塊var http = require('http');//url解析模塊var url = require('url');//文件系統模塊var fs = require("fs");//路徑解析模塊var path = require("path");

創建服務并在指定的端口監聽:

//創建一個服務var httpServer = http.createServer(this.processRequest.bind(this));//在指定的端口監聽服務httpServer.listen(port,function(){  console.log("[HttpServer][Start]","runing at http://"+ip+":"+port+"/");  console.timeEnd("[HttpServer][Start]");});

在創建服務的時候需要傳遞一個匿名函數processRequest 對請求進行處理,processRequest接收2個參數,分別是request和response, request對象中包含了請求的所有內容,response是用來設置響應頭以及對客戶端做出響應操作。

processRequest:function(request,response){  var hasExt = true;  var requestUrl = request.url;  var pathName = url.parse(requestUrl).pathname;  //對請求的路徑進行解碼,防止中文亂碼  pathName = decodeURI(pathName);  //如果路徑中沒有擴展名  if(path.extname(pathName) === ''){    //如果不是以/結尾的,加/并作301重定向    if (pathName.charAt(pathName.length-1) != "/"){      pathName += "/";      var redirect = "http://"+request.headers.host + pathName;      response.writeHead(301, {        location:redirect      });      response.end();    }    //添加默認的訪問頁面,但這個頁面不一定存在,后面會處理    pathName += "index.html";    hasExt = false; //標記默認頁面是程序自動添加的  }  //獲取資源文件的相對路徑  var filePath = path.join("http/webroot",pathName);  //獲取對應文件的文檔類型  var contentType = this.getContentType(filePath);  //如果文件名存在  fs.exists(filePath,function(exists){    if(exists){      response.writeHead(200, {"content-type":contentType});      var stream = fs.createReadStream(filePath,{flags:"r",encoding:null});      stream.on("error", function() {        response.writeHead(500,{"content-type": "text/html"});        response.end("<h1>500 Server Error</h1>");      });      //返回文件內容      stream.pipe(response);    }else { //文件名不存在的情況      if(hasExt){        //如果這個文件不是程序自動添加的,直接返回404        response.writeHead(404, {"content-type": "text/html"});        response.end("<h1>404 Not Found</h1>");      }else {        //如果文件是程序自動添加的且不存在,則表示用戶希望訪問的是該目錄下的文件列表        var html = "<head><meta charset='utf-8'></head>";        try{          //用戶訪問目錄          var filedir = filePath.substring(0,filePath.lastIndexOf('//'));          //獲取用戶訪問路徑下的文件列表          var files = fs.readdirSync(filedir);          //將訪問路徑下的所以文件一一列舉出來,并添加超鏈接,以便用戶進一步訪問          for(var i in files){            var filename = files[i];            html += "<div><a href='"+filename+"'>"+filename+"</a></div>";          }        }catch (e){          html += "<h1>您訪問的目錄不存在</h1>"        }        response.writeHead(200, {"content-type": "text/html"});        response.end(html);      }    }  });},

請求處理函數中有幾個重點需要說一下:

對于路徑中有中文的,瀏覽器會自動進行編碼(英文不變,中文會變),因此在接收到地址后,需要對地址進行解碼,否則最后得到的路徑和真實路徑不相符,

當訪問路徑不是以具體的文件結尾,并且不是以/結尾,則需要通過重定向加上/,表示當前目錄,否則當前路徑下的靜態資源會找不到

如果訪問路徑是目錄,則列出該目錄下所有文件及文件夾,并可以點擊訪問,為了讓中文目錄能正常顯示,則還要在header中設置charset=utf-8

核心代碼就這么多,大概140行左右,完整的代碼已上傳到http://xiazai.VeVB.COm/201611/yuanma/Node-master(VeVB.COm).rar

如果要運行demo,打開cmd切換到根目錄,運行node start即可。

如有問題,歡迎討論!

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永年县| 蕉岭县| 宣威市| 宣城市| 五华县| 凌海市| 西峡县| 广宗县| 始兴县| 萍乡市| 易门县| 西青区| 丰镇市| 文安县| 措美县| 奉贤区| 德惠市| 阿拉尔市| 北辰区| 井冈山市| 阳泉市| 吴堡县| 辉县市| 洛浦县| 广东省| 遂宁市| 河东区| 东台市| 汉川市| 那曲县| 三明市| 东阿县| 原阳县| 辽阳市| 甘泉县| 南漳县| 买车| 即墨市| 芒康县| 夹江县| 大新县|