nodejs如何創(chuàng)建簡易web服務(wù)器與文件讀寫

小編給大家分享一下nodejs如何創(chuàng)建簡易web服務(wù)器與文件讀寫,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

在公安等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站制作、成都網(wǎng)站設(shè)計、外貿(mào)營銷網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作按需求定制網(wǎng)站,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計,成都營銷網(wǎng)站建設(shè),成都外貿(mào)網(wǎng)站建設(shè)公司,公安網(wǎng)站建設(shè)費(fèi)用合理。

web服務(wù)器至少有以下幾個特點(diǎn):

1、24小時不停止的工作,也就是說這個進(jìn)程要常駐在內(nèi)存中

2、24小時在某一端口監(jiān)聽,如: http://localhost:8080, www服務(wù)器默認(rèn)端口80

3、要能夠處理基本的請求:如get, post

在node js中創(chuàng)建一臺服務(wù)器非常的簡單,因為node自帶http模塊,該模塊可以幫助我們非??焖俅罱ㄒ慌_web服務(wù)器,來處理一個簡單的請求.

 const http = require("http");
 var server = http.createServer(function(){
  console.log( '有人訪問ghostwu的服務(wù)器' );
 });
 server.listen( 8080 );

第1行:導(dǎo)入node js內(nèi)置的http模塊

第2行: 利用http模塊自帶的createServer方法,創(chuàng)建一臺服務(wù)器

第5行: 服務(wù)器在8080端口監(jiān)聽

然后切換到文件所在的路徑,用node 運(yùn)行這個文件( node + 文件名 ),然后在瀏覽器中輸入( http://localhost:8080 )就可以看見控制臺 打印出 '有人訪問ghostwu的服務(wù)器'

nodejs如何創(chuàng)建簡易web服務(wù)器與文件讀寫

nodejs如何創(chuàng)建簡易web服務(wù)器與文件讀寫

但是這個服務(wù)器有個問題,只能在控制臺輸出信息,一般的服務(wù)器都會向瀏覽器輸出信息,怎么做呢?

const http = require("http");
var server = http.createServer(function( req, res ){
 res.write( 'http://www.cnblogs.com/ghostwu/' );
 res.end();
});
server.listen( 6060 );

createServer的時候,為回調(diào)函數(shù)傳遞2個參數(shù),第一個參數(shù)是處理請求的, 第二個參數(shù)是處理響應(yīng)的,而我們要想把服務(wù)器的信息輸出到瀏覽器,就需要調(diào)用res對象的write方法,然后調(diào)用end方法結(jié)束輸出。在瀏覽器輸入: localhost:6060,就能看到 http://www.cnblogs.com/ghostwu/

但是這臺服務(wù)器,還是有個問題,只能處理http://localhost:6060 這樣一個固定的端口和網(wǎng)址的請求, 其他的請求輸出都是 看到同樣的東西,而實際的請求卻是:

http://localhost:8080 訪問首頁

http://localhost/404.html 訪問404頁面

http://localhost/1.html 訪問1.html

。。。。

等等,不同的url請求,應(yīng)該把對應(yīng)的文件信息讀出來,再輸出到瀏覽器,我們先來做這個功能,不同的url顯示不同的信息:

const http = require("http");
var server = http.createServer(function( req, res ){
 switch( req.url ){
  case '/1.html' :
   res.write( '1.html' );
   break;
  case '/2.html':
   res.write( '2.html' );
   break;
  default: 
   res.write( '404' );
 }
 res.end();
});

server.listen( 8080 );

這樣就能處理 http://localhost:8080/1.html --> 顯示1.html http://localhost:8080/2.html ---> 顯示2.html 其他的請求都是顯示404

最后,我們只需要,在對應(yīng)的分支,把對應(yīng)的文件內(nèi)容讀取出來就可以了,那么node js怎么讀取文件呢?

var fs =require('fs');
fs.readFile("1.txt", function( err, data ){
 if( err ){
  console.log( err )
 }else {
  console.log( data.toString() );
 }
});

需要包含fs模塊,這個模塊就是處理文件的

readFile, 第一個參數(shù),具體的文件路徑和名稱, 第二個參數(shù)回調(diào)函數(shù)有2個參數(shù),一個是錯誤結(jié)果,一個是文件中的數(shù)據(jù), 數(shù)據(jù)需要用toString方法轉(zhuǎn)一下,否則就是字節(jié)數(shù)據(jù),還有1.txt這個文件要確實存在.

寫文件用writeFile這個api,b.txt如果不存在會自動創(chuàng)建一個,往b.txt文件中插入內(nèi)容' this is b.txt'

const fs = require("fs");
fs.writeFile( "b.txt", "this is b.txt", function( err ){
 console.log( err );
} );

有了文件讀寫功能,我們就可以結(jié)合上面的代碼,實現(xiàn)一個簡易的get請求服務(wù)器

文件結(jié)構(gòu):

nodejs如何創(chuàng)建簡易web服務(wù)器與文件讀寫

server.js:

var http = require("http");
var fs = require("fs");
var server = http.createServer(function( req, res ){
 var fileName = './www' + req.url;
 fs.readFile( fileName, function( err, data ){
  if( err ){
   res.write( '404' );
  }else {
   res.write( data );
  }
  res.end();
 } );
}).listen( 8080 );

然后,在瀏覽器輸入:

http://localhost:8080/index.html 就能讀出www目錄下面index.html的內(nèi)容

http://localhost:8080/category.html 就能讀出www目錄下面category.html的內(nèi)容

其他請求,輸出404

以上是“nodejs如何創(chuàng)建簡易web服務(wù)器與文件讀寫”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

文章名稱:nodejs如何創(chuàng)建簡易web服務(wù)器與文件讀寫
URL網(wǎng)址:http://muchs.cn/article48/pdgcep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設(shè)響應(yīng)式網(wǎng)站、虛擬主機(jī)、外貿(mào)網(wǎng)站建設(shè)、電子商務(wù)、App設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)