欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Nodejs 搭建簡(jiǎn)單的Web服務(wù)器詳解及實(shí)例

 更新時(shí)間:2016年11月30日 09:24:23   作者:一像素  
這篇文章主要介紹了Nodejs 搭建簡(jiǎn)單的Web服務(wù)器詳解及實(shí)例的相關(guān)資料,并附實(shí)例代碼和實(shí)現(xiàn)效果圖,需要的朋友可以參考下

使用 Nodejs 搭建簡(jiǎn)單的Web服務(wù)器

使用Nodejs搭建Web服務(wù)器是學(xué)習(xí)Node.js比較全面的入門教程,因?yàn)橐瓿梢粋€(gè)簡(jiǎn)單的Web服務(wù)器,你需要學(xué)習(xí)Nodejs中幾個(gè)比較重要的模塊,比如:http協(xié)議模塊、文件系統(tǒng)、url解析模塊、路徑解析模塊、以及301重定向問題,下面我們就簡(jiǎn)單講一下如何來搭建一個(gè)簡(jiǎn)單的Web服務(wù)器。

作為一個(gè)Web服務(wù)器應(yīng)具備以下幾個(gè)功能:

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

2、能直接打開以.js/.css/.json/.text結(jié)尾的文件內(nèi)容

3、顯示圖片資源

4、自動(dòng)下載以.apk/.docx/.zip結(jié)尾的文件

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

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

 引入需要用到的幾個(gè)模塊:

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

創(chuàng)建服務(wù)并在指定的端口監(jiān)聽:

//創(chuàng)建一個(gè)服務(wù)
var httpServer = http.createServer(this.processRequest.bind(this));

//在指定的端口監(jiān)聽服務(wù)
httpServer.listen(port,function(){
  console.log("[HttpServer][Start]","runing at http://"+ip+":"+port+"/");
  console.timeEnd("[HttpServer][Start]");
});

在創(chuàng)建服務(wù)的時(shí)候需要傳遞一個(gè)匿名函數(shù)processRequest 對(duì)請(qǐng)求進(jìn)行處理,processRequest接收2個(gè)參數(shù),分別是request和response, request對(duì)象中包含了請(qǐng)求的所有內(nèi)容,response是用來設(shè)置響應(yīng)頭以及對(duì)客戶端做出響應(yīng)操作。

processRequest:function(request,response){
  var hasExt = true;
  var requestUrl = request.url;
  var pathName = url.parse(requestUrl).pathname;

  //對(duì)請(qǐng)求的路徑進(jìn)行解碼,防止中文亂碼
  pathName = decodeURI(pathName);

  //如果路徑中沒有擴(kuò)展名
  if(path.extname(pathName) === ''){
    //如果不是以/結(jié)尾的,加/并作301重定向
    if (pathName.charAt(pathName.length-1) != "/"){
      pathName += "/";
      var redirect = "http://"+request.headers.host + pathName;
      response.writeHead(301, {
        location:redirect
      });
      response.end();
    }
    //添加默認(rèn)的訪問頁面,但這個(gè)頁面不一定存在,后面會(huì)處理
    pathName += "index.html";
    hasExt = false; //標(biāo)記默認(rèn)頁面是程序自動(dòng)添加的
  }

  //獲取資源文件的相對(duì)路徑
  var filePath = path.join("http/webroot",pathName);

  //獲取對(duì)應(yīng)文件的文檔類型
  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>");
      });
      //返回文件內(nèi)容
      stream.pipe(response);
    }else { //文件名不存在的情況
      if(hasExt){
        //如果這個(gè)文件不是程序自動(dòng)添加的,直接返回404
        response.writeHead(404, {"content-type": "text/html"});
        response.end("<h1>404 Not Found</h1>");
      }else {
        //如果文件是程序自動(dòng)添加的且不存在,則表示用戶希望訪問的是該目錄下的文件列表
        var html = "<head><meta charset='utf-8'></head>";

        try{
          //用戶訪問目錄
          var filedir = filePath.substring(0,filePath.lastIndexOf('\\'));
          //獲取用戶訪問路徑下的文件列表
          var files = fs.readdirSync(filedir);
          //將訪問路徑下的所以文件一一列舉出來,并添加超鏈接,以便用戶進(jìn)一步訪問
          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);
      }
    }
  });
},

請(qǐng)求處理函數(shù)中有幾個(gè)重點(diǎn)需要說一下:

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

當(dāng)訪問路徑不是以具體的文件結(jié)尾,并且不是以/結(jié)尾,則需要通過重定向加上/,表示當(dāng)前目錄,否則當(dāng)前路徑下的靜態(tài)資源會(huì)找不到

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

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

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

如有問題,歡迎討論!

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

相關(guān)文章

  • node 使用 async 控制并發(fā)的方法

    node 使用 async 控制并發(fā)的方法

    這篇文章主要介紹了node 使用 async 控制并發(fā)的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-05-05
  • Nodejs關(guān)于gzip/deflate壓縮詳解

    Nodejs關(guān)于gzip/deflate壓縮詳解

    本文主要向大家介紹了nodejs中關(guān)于gzip/deflate壓縮的2種方法,分別是管道壓縮和非管道壓縮,十分詳細(xì),并附帶示例,這里推薦給大家參考下。
    2015-03-03
  • node.js中的fs.writeFile方法使用說明

    node.js中的fs.writeFile方法使用說明

    這篇文章主要介紹了node.js中的fs.writeFile方法使用說明,本文介紹了fs.writeFile的方法說明、語法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • Node.js服務(wù)端實(shí)戰(zhàn)之服務(wù)啟動(dòng)過程詳解

    Node.js服務(wù)端實(shí)戰(zhàn)之服務(wù)啟動(dòng)過程詳解

    這篇文章主要為大家介紹了Node.js服務(wù)端實(shí)戰(zhàn)之服務(wù)啟動(dòng)過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • express文件上傳中間件Multer詳解

    express文件上傳中間件Multer詳解

    multer是express官方推薦的文件上傳中間件,它是在busboy的基礎(chǔ)上開發(fā)的。目前multer的最新版本為:~1.1.0。本文將詳細(xì)介紹express文件上傳中間件Multer的安裝與使用等,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-10-10
  • 淺析Node.js實(shí)現(xiàn)HTTP文件下載

    淺析Node.js實(shí)現(xiàn)HTTP文件下載

    本文介紹如何用Node.js來實(shí)現(xiàn)HTTP文件下載,文章以實(shí)例演示所以很詳細(xì),有需要的小伙伴們可以參考學(xué)習(xí)。
    2016-08-08
  • node使用mysql獲取數(shù)據(jù)庫數(shù)據(jù)中文亂碼問題的解決

    node使用mysql獲取數(shù)據(jù)庫數(shù)據(jù)中文亂碼問題的解決

    這篇文章主要介紹了node使用mysql獲取數(shù)據(jù)庫數(shù)據(jù)中文亂碼問題的解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • node+koa+canvas繪制出貨單、收據(jù)票據(jù)的方法

    node+koa+canvas繪制出貨單、收據(jù)票據(jù)的方法

    在生成票據(jù)需求中,我們會(huì)想到前端生成或者后端生成返回圖片地址訪問兩個(gè)方法,前端生成則不需要調(diào)用接口,而后端是在完成整個(gè)流程時(shí)就進(jìn)行生成然后把上傳的地址保存數(shù)據(jù)庫,這篇文章主要介紹了node+koa+canvas繪制出貨單,收據(jù),票據(jù),需要的朋友可以參考下
    2022-09-09
  • Node.js調(diào)試技術(shù)總結(jié)分享

    Node.js調(diào)試技術(shù)總結(jié)分享

    Node.js是一個(gè)可以快速構(gòu)建網(wǎng)絡(luò)服務(wù)及應(yīng)用的平臺(tái)。該平臺(tái)的構(gòu)建是基于Chrome's JavaScript runtime,也就是說,實(shí)際上它是對(duì)Google V8引擎(應(yīng)用于Google Chrome瀏覽器)進(jìn)行了封裝。 今天介紹Node.js調(diào)式目前有幾種技術(shù),需要的朋友可以參考下。
    2017-03-03
  • node.js抓取并分析網(wǎng)頁內(nèi)容有無特殊內(nèi)容的js文件

    node.js抓取并分析網(wǎng)頁內(nèi)容有無特殊內(nèi)容的js文件

    nodejs獲取網(wǎng)頁內(nèi)容綁定data事件,獲取到的數(shù)據(jù)會(huì)分幾次相應(yīng),如果想全局內(nèi)容匹配,需要等待請(qǐng)求結(jié)束,在end結(jié)束事件里把累積起來的全局?jǐn)?shù)據(jù)進(jìn)行操作,本文給大家介紹node.js抓取并分析網(wǎng)頁內(nèi)容有無特殊內(nèi)容的js文件,需要的朋友參考下
    2015-11-11

最新評(píng)論