Nodejs如何搭建Web服務(wù)器
使用Nodejs搭建Web服務(wù)器是學(xué)習(xí)Node.js比較全面的入門(mén)教程,因?yàn)橐瓿梢粋€(gè)簡(jiǎn)單的Web服務(wù)器,你需要學(xué)習(xí)Nodejs中幾個(gè)比較重要的模塊,比如:http協(xié)議模塊、文件系統(tǒng)、url解析模塊、路徑解析模塊、以及301重定向問(wèn)題,下面我們就簡(jiǎn)單講一下如何來(lái)搭建一個(gè)簡(jiǎn)單的Web服務(wù)器。
作為一個(gè)Web服務(wù)器應(yīng)具備以下幾個(gè)功能:
1、能顯示以.html/.htm結(jié)尾的Web頁(yè)面
2、能直接打開(kāi)以.js/.css/.json/.text結(jié)尾的文件內(nèi)容
3、顯示圖片資源
4、自動(dòng)下載以.apk/.docx/.zip結(jié)尾的文件
5、形如http://xxx.com/a/b/ , 則查找b目錄下是否有index.html,如果有就顯示,如果沒(méi)有就列出該目錄下的所有文件及文件夾,并可以進(jìn)一步訪(fǎng)問(wèn)。
6、形如http://xxx.com/a/b, 則作301重定向到http://xxx.com/a/b/ , 這樣可以解決內(nèi)部資源引用錯(cuò)位的問(wèn)題。
引入需要用到的幾個(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)聽(tīng):
//創(chuàng)建一個(gè)服務(wù) var httpServer = http.createServer(this.processRequest.bind(this)); //在指定的端口監(jiān)聽(tīng)服務(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)容,request是用來(lái)設(shè)置響應(yīng)頭以及對(duì)客戶(hù)端做出響應(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); //如果路徑中沒(méi)有擴(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)的訪(fǎng)問(wèn)頁(yè)面,但這個(gè)頁(yè)面不一定存在,后面會(huì)處理 pathName += "index.html"; hasExt = false; //標(biāo)記默認(rèn)頁(yè)面是程序自動(dòng)添加的 } //獲取資源文件的相對(duì)路徑 var filePath = path.join("http/webroot",pathName); //獲取對(duì)應(yīng)文件的文檔類(lèi)型 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)添加的且不存在,則表示用戶(hù)希望訪(fǎng)問(wèn)的是該目錄下的文件列表 var html = "<head><meta charset='utf-8'></head>"; try{ //用戶(hù)訪(fǎng)問(wèn)目錄 var filedir = filePath.substring(0,filePath.lastIndexOf('\\')); //獲取用戶(hù)訪(fǎng)問(wèn)路徑下的文件列表 var files = fs.readdirSync(filedir); //將訪(fǎng)問(wèn)路徑下的所以文件一一列舉出來(lái),并添加超鏈接,以便用戶(hù)進(jìn)一步訪(fǎng)問(wèn) for(var i in files){ var filename = files[i]; html += "<div><a href='"+filename+"'>"+filename+"</a></div>"; } }catch (e){ html += "<h1>您訪(fǎng)問(wèn)的目錄不存在</h1>" } response.writeHead(200, {"content-type": "text/html"}); response.end(html); } } }); },
請(qǐng)求處理函數(shù)中有幾個(gè)重點(diǎn)需要說(shuō)一下:
對(duì)于路徑中有中文的,瀏覽器會(huì)自動(dòng)進(jìn)行編碼(英文不變,中文會(huì)變),因此在接收到地址后,需要對(duì)地址進(jìn)行解碼,否則最后得到的路徑和真實(shí)路徑不相符,
當(dāng)訪(fǎng)問(wèn)路徑不是以具體的文件結(jié)尾,并且不是以/結(jié)尾,則需要通過(guò)重定向加上/,表示當(dāng)前目錄,否則當(dāng)前路徑下的靜態(tài)資源會(huì)找不到
如果訪(fǎng)問(wèn)路徑是目錄,則列出該目錄下所有文件及文件夾,并可以點(diǎn)擊訪(fǎng)問(wèn),為了讓中文目錄能正常顯示,則還要在header中設(shè)置charset=utf-8
核心代碼就這么多,大概140行左右,完整的代碼已上傳到Git:https://github.com/git-onepixel/Node
如果要運(yùn)行demo,打開(kāi)cmd切換到根目錄,運(yùn)行node start即可。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。
相關(guān)文章
快速搭建Node.js(Express)用戶(hù)注冊(cè)、登錄以及授權(quán)的方法
這篇文章主要介紹了快速搭建Node.js(Express)用戶(hù)注冊(cè)、登錄以及授權(quán),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-05-05NodeJS通過(guò)魔術(shù)封包喚醒局域網(wǎng)計(jì)算機(jī)實(shí)例
這篇文章主要為大家介紹了NodeJS通過(guò)魔術(shù)封包喚醒局域網(wǎng)計(jì)算機(jī)代碼實(shí)例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06Nginx設(shè)置為Node.js的前端服務(wù)器方法總結(jié)
在本篇文章中小編給大家分享了關(guān)于Nginx設(shè)置為Node.js的前端服務(wù)器的方法和實(shí)例,需要的朋友們學(xué)習(xí)下。2019-03-03node.js中的http.response.getHeader方法使用說(shuō)明
這篇文章主要介紹了node.js中的http.response.getHeader方法使用說(shuō)明,本文介紹了http.response.getHeader的方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下2014-12-12nodejs搭建本地服務(wù)器輕松解決跨域問(wèn)題
這篇文章主要介紹了利用nodejs搭建本地服務(wù)器 解決跨域問(wèn)題,需要的朋友可以參考下2018-03-03使用NestJS開(kāi)發(fā)Node.js應(yīng)用的方法
這篇文章主要介紹了使用NestJS開(kāi)發(fā)Node.js應(yīng)用的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12Node.js斷點(diǎn)續(xù)傳的實(shí)現(xiàn)
最近做了個(gè)項(xiàng)目,應(yīng)項(xiàng)目需求,需要傳圖片、Excel等,幾M的大小可以很快就上傳到服務(wù)器,但是大的就需要斷點(diǎn)上傳,本文就介紹一下,感興趣的可以了解一下2021-05-05