<dfn id="mexiu"><input id="mexiu"></input></dfn>
  • <li id="mexiu"><nobr id="mexiu"><sub id="mexiu"></sub></nobr></li>
    <i id="mexiu"><dl id="mexiu"></dl></i>
    • Nodejs如何搭建Web服務(wù)器
      來源:易賢網(wǎng) 閱讀:1267 次 日期:2016-07-15 15:52:35
      溫馨提示:易賢網(wǎng)小編為您整理了“Nodejs如何搭建Web服務(wù)器”,方便廣大網(wǎng)友查閱!

      這篇文章主要介紹了Nodejs如何搭建Web服務(wù)器,本文教大家使用 Nodejs搭建一個簡單的Web服務(wù)器,感興趣的小伙伴們可以參考一下

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

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

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

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

      3、顯示圖片資源

      4、自動下載以.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)部資源引用錯位的問題。 

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

      //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)建一個服務(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ù)processRequest 對請求進(jìn)行處理,processRequest接收2個參數(shù),分別是request和response, request對象中包含了請求的所有內(nèi)容,request是用來設(shè)置響應(yīng)頭以及對客戶端做出響應(yīng)操作。

      processRequest:function(request,response){

        var hasExt = true;

        var requestUrl = request.url;

        var pathName = url.parse(requestUrl).pathname;

        //對請求的路徑進(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)的訪問頁面,但這個頁面不一定存在,后面會處理

          pathName += "index.html";

          hasExt = false; //標(biāo)記默認(rèn)頁面是程序自動添加的

        }

        //獲取資源文件的相對路徑

        var filePath = path.join("http/webroot",pathName);

        //獲取對應(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){

              //如果這個文件不是程序自動添加的,直接返回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);

                //將訪問路徑下的所以文件一一列舉出來,并添加超鏈接,以便用戶進(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);

            }

          }

        });

      },

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

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

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

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

      核心代碼就這么多,大概140行左右,完整的代碼已上傳到Git:https://github.com/git-onepixel/Node

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

      以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。

      更多信息請查看網(wǎng)絡(luò)編程
      易賢網(wǎng)手機(jī)網(wǎng)站地址:Nodejs如何搭建Web服務(wù)器
      由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!
      關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機(jī)站點(diǎn)

      版權(quán)所有:易賢網(wǎng)