淺談使用nodejs搭建web服務器的過程
使用 Node 創(chuàng)建 Web 服務器
什么是 Web 服務器?
Web服務器一般指網(wǎng)站服務器,是指駐留于因特網(wǎng)上某種類型計算機的程序,Web服務器的基本功能就是提供Web信息瀏覽服務。它只需支持HTTP協(xié)議、HTML文檔格式及URL,與客戶端的網(wǎng)絡瀏覽器配合。
大多數(shù) web 服務器都支持服務端的腳本語言(php、python、ruby)等,并通過腳本語言從數(shù)據(jù)庫獲取數(shù)據(jù),將結果返回給客戶端瀏覽器。
目前最主流的三個Web服務器是Apache、Nginx、IIS。
Node.js 提供了 http 模塊,http 模塊主要用于搭建 HTTP 服務端和客戶端,使用 HTTP 服務器或客戶端功能必須調(diào)用 http 模塊,代碼如下:
var http = require('http');
在通常的服務器中,數(shù)據(jù)流通的方式是客戶先通過瀏覽器進行發(fā)送請求,服務器在項目中進行查找,然后進客戶所需要的頁面進行返回,在查找的過程中可能存在兩種情況,就是存在和不存在,當然,我們會做出判斷,下面就是簡單的服務器實現(xiàn)過程:
1、編寫服務器代碼server.js
var http=require('http'); var fs = require('fs'); var url = require('url'); //創(chuàng)建服務器 http.createServer(function(request,response) { //解析請求,包括文件名 var pathname= url.parse(request.url).pathname; //輸出請求的文件名 console.log("Request for "+ pathname + " received."); //從文件系統(tǒng)中都去請求的文件內(nèi)容 fs.readFile(pathname.substr(1),function(err, data) { if(err) { console.log(err); //HTTP 狀態(tài)碼 404 : NOT FOUND //Content Type:text/plain response.writeHead(404,{'Content-Type': 'text/html'}); } else { //HTTP 狀態(tài)碼 200 : OK //Content Type:text/plain response.writeHead(200,{'Content-Type': 'text/html'}); //寫會相應內(nèi)容 response.write(data.toString()); } //發(fā)送響應數(shù)據(jù) response.end(); }); }).listen(8081); console.log('Server running at http://127.0.0.1:8081/');
通過上面代碼,我們就能夠?qū)崿F(xiàn)服務器對于文件的查找,下面,我們就進行創(chuàng)建一個html文件,然后通過瀏覽器進行訪問
2、編寫html文件(index.html),用于瀏覽器進行請求
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>index</title> </head> <body> 這是一個用于進行nodejs服務器測試的html文件,我們能夠通過在瀏覽器上面輸入 http://127.0.0.1:8081/WebServer/index.html進行訪問 </body> </html>
創(chuàng)建完之后,我們進行測試,現(xiàn)在我的目錄結構是這樣的:
3、進行測試
(1) 首先我們啟動服務器,使用命令node WebServer/server.js
(2) 在瀏覽器進行訪問,在url欄中輸入http://127.0.0.1:8081/WebServer/index.html
其顯示效果如下所示:
后臺效果如下所示:
當然,我們也能夠通過訪問通過http://127.0.0.1:8081/LoveYou.html訪
問server.js文件夾外邊的文件,進行到這里,我們就可以得到文件返回給前端,但是有些同學可能會問,樣式該怎么做??如下面代碼,我們進行了樣式的定義,修改了兩個div的大小,并且給div設置邊框
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>index</title> <style> body { border: 1px solid red; } div { border-radius: 10px; width: 500px; height: 200px; border: 2px solid green; } </style> </head> <body> 這是一個用于進行nodejs服務器測試的html文件,我們能夠通過在瀏覽器上面輸入 http://127.0.0.1:8081/WebServer/index.html進行訪問 <div>1</div> <div>2</div> </body> </html>
效果如下所示
有了這些,我們還會問,你這樣直接將樣式寫在html中,我可不干,我要把樣式寫道另外單獨一個文件中,然后通過引用的方式引入,于是就會有人使用下面代碼:
<link rel="stylesheet" rel="external nofollow" >
然而,這段代碼并不會起作用,因為傳遞給前端的方式Content-Type是有問題的,需要我們的服務器進行下一步操作,也就是處理靜態(tài)文件。既然傳給前端時需要告訴type是css,那么我們就進行區(qū)分對待,如下面代碼,我們對server.js進行修改如下:
var http=require('http'); var fs = require('fs'); var url = require('url'); //創(chuàng)建服務器 http.createServer(function(request,response) { //解析請求,包括文件名 var pathname= url.parse(request.url).pathname; //輸出請求的文件名 console.log("Request for "+ pathname + " received."); //當請求static文件夾時,設置文件返回類型是text/css var firstDir = pathname && pathname.split('/')[2]; var ContentType = null; if (firstDir && firstDir === 'static') { ContentType = {'Content-Type': 'text/css'}; } else { ContentType = {'Content-Type': 'text/html'} } //從文件系統(tǒng)中去請求的文件內(nèi)容 fs.readFile(pathname.substr(1),function(err, data) { if(err) { console.log(err); //HTTP 狀態(tài)碼 404 : NOT FOUND //Content Type:text/plain response.writeHead(404, {'Content-Type': 'text/html'}); } else { //HTTP 狀態(tài)碼 200 : OK //Content Type:text/plain response.writeHead(200, ContentType); //寫會回相應內(nèi)容 response.write(data.toString()); } //發(fā)送響應數(shù)據(jù) response.end(); }); }).listen(8081); console.log('Server running at http://127.0.0.1:8081/');
接著,我們需要在項目中創(chuàng)建一個static文件夾,如下面所示結構:
在static文件夾中創(chuàng)建index.css文件,代碼內(nèi)容如下所示:
body { border: 1px solid blue; } div { border-radius: 10px; width: 400px; height: 200px; border: 2px solid yellow; }
也就是修改body邊框為藍色,div邊框為黃色,同時我們需要更新index.html中文件內(nèi)容如下所示:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>index</title> <link rel="stylesheet" rel="external nofollow" > </head> <body> 這是一個用于進行nodejs服務器測試的html文件,我們能夠通過在瀏覽器上面輸入 http://127.0.0.1:8081/WebServer/index.html進行訪問 <div>1</div> <div>2</div> </body> </html>
也就是通過引入的方式將樣式引入到html文件中,然后在瀏覽器查看內(nèi)容,效果如下所示:
很明顯,我們的樣式已經(jīng)通過引入的方式引進到html頁面中了,同樣的原理,我們能夠進行將js也通過引入的方式進行使用,在這里我就不一一貼出代碼了,看看效果如下所示:
在上面效果中,當我點擊2號div的時候,將會調(diào)用我在js文件夾中的方法去執(zhí)行彈窗,詳細代碼請到github下載:https://github.com/suwu150/node-http-server
使用 Node 創(chuàng)建 Web 客戶端
Node 創(chuàng)建 Web 客戶端需要引入 http 模塊,創(chuàng)建 client.js 文件,代碼如下所示:
var http = require('http'); //用于請求的選項 var options = { host: 'localhost', port: '8081', path: '/WebServer/index.html' }; //處理響應的回調(diào)函數(shù) var callback= function(response) { //不斷更新數(shù)據(jù) var body = ''; response.on('data',function(data) { body+=data; }); response.on('end', function() { //數(shù)據(jù)接收完成 console.log(body); }); }; //向服務器端發(fā)送請求 var req = http.request(options, callback); req.end();
新打開終端,運行程序如下所示:
對與服務器,可以參見我以前寫過的服務器,其工作原理是一致的:http://www.dbjr.com.cn/article/191240.htm 這是使用java進行寫的服務器
到此這篇關于淺談使用nodejs搭建web服務器的過程的文章就介紹到這了,更多相關nodejs搭建web服務器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
我用的一些Node.js開發(fā)工具、開發(fā)包、框架等總結
這篇文章主要介紹了我個人使用的一些Node.js開發(fā)工具、開發(fā)包、框架等總結,需要的朋友可以參考下2014-09-09node.js中的buffer.toString方法使用說明
這篇文章主要介紹了node.js中的buffer.toString方法使用說明,本文介紹了buffer.toString的方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下2014-12-12Node.js操作MongoDB數(shù)據(jù)庫實例分析
這篇文章主要介紹了Node.js操作MongoDB數(shù)據(jù)庫,結合實例形式分析了node.js連接MongoDB數(shù)據(jù)庫以及增刪改查等相關操作技巧,需要的朋友可以參考下2020-01-01