小編給大家分享一下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ù)器'
但是這個服務(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):
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)