輕松創(chuàng)建nodejs服務(wù)器(6):作出響應(yīng)
我們接著改造服務(wù)器,讓請(qǐng)求處理程序能夠返回一些有意義的信息。
我們來(lái)看看如何實(shí)現(xiàn)它:
1、讓請(qǐng)求處理程序通過(guò)onRequest函數(shù)直接返回(return())他們要展示給用戶(hù)的信息。
2、讓我們從讓請(qǐng)求處理程序返回需要在瀏覽器中顯示的信息開(kāi)始。
我們需要將requestHandler.js修改為如下形式:
function start() {
console.log("Request handler 'start' was called.");
return "Hello Start";
}
function upload() {
console.log("Request handler 'upload' was called.");
return "Hello Upload";
}
exports.start = start;
exports.upload = upload;
同樣的,請(qǐng)求路由需要將請(qǐng)求處理程序返回給它的信息返回給服務(wù)器。
因此,我們需要將router.js修改為如下形式:
function route(handle, pathname) {
console.log("About to route a request for " + pathname);
if (typeof handle[pathname] === 'function') {
return handle[pathname]();
} else {
console.log("No request handler found for " + pathname);
return "404 Not found";
}
}
exports.route=route;
正如上述代碼所示,當(dāng)請(qǐng)求無(wú)法路由的時(shí)候,我們也返回了一些相關(guān)的錯(cuò)誤信息。
最后,我們需要對(duì)我們的server.js進(jìn)行重構(gòu)以使得它能夠?qū)⒄?qǐng)求處理程序通過(guò)請(qǐng)求路由返回的內(nèi)容響應(yīng)給瀏覽器,如下所示:
var http = require("http");
var url = require("url");
function start(route, handle) {
function onRequest(request, response) {
var pathname = url.parse(request.url).pathname;
console.log("Request for " + pathname + " received.");
response.writeHead(200, {"Content-Type": "text/plain"});
var content = route(handle, pathname);
response.write(content);
response.end();
}
http.createServer(onRequest).listen(8888);
console.log("Server has started.");
}
exports.start=start;
如果我們運(yùn)行重構(gòu)后的應(yīng)用:
請(qǐng)求http://localhost:8888/start,瀏覽器會(huì)輸出“Hello Start”,
請(qǐng)求http://localhost:8888/upload會(huì)輸出“Hello Upload”,
而請(qǐng)求http://localhost:8888/foo 會(huì)輸出“404 Not found”。
這感覺(jué)不錯(cuò),下一節(jié)我們要來(lái)了解一個(gè)概念:阻塞操作。
- 輕松創(chuàng)建nodejs服務(wù)器(10):處理POST請(qǐng)求
- 輕松創(chuàng)建nodejs服務(wù)器(7):阻塞操作的實(shí)現(xiàn)
- 輕松創(chuàng)建nodejs服務(wù)器(5):事件處理程序
- 輕松創(chuàng)建nodejs服務(wù)器(4):路由
- 輕松創(chuàng)建nodejs服務(wù)器(3):代碼模塊化
- 輕松創(chuàng)建nodejs服務(wù)器(2):nodejs服務(wù)器的構(gòu)成分析
- 輕松創(chuàng)建nodejs服務(wù)器(1):一個(gè)簡(jiǎn)單nodejs服務(wù)器例子
- 零基礎(chǔ)搭建Node.js、Express、Ejs、Mongodb服務(wù)器及應(yīng)用開(kāi)發(fā)入門(mén)
- 用用outlook Express 由于服務(wù)器拒絕接受發(fā)件人的電子郵件地址,這封郵件無(wú)法發(fā)送
- Express與NodeJs創(chuàng)建服務(wù)器的兩種方法
相關(guān)文章
koa2 數(shù)據(jù)api中間件設(shè)計(jì)模型的實(shí)現(xiàn)方法
這篇文章主要介紹了koa2 數(shù)據(jù)api中間件設(shè)計(jì)模型的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07webpack創(chuàng)建項(xiàng)目并打包的詳細(xì)流程記錄
webpack在前端工程領(lǐng)域起到了中流砥柱的作用,理解它的內(nèi)部實(shí)現(xiàn)機(jī)制會(huì)對(duì)你的工程建設(shè)提供很大的幫助(不論是定制功能還是優(yōu)化打包),下面這篇文章主要給大家介紹了關(guān)于webpack創(chuàng)建項(xiàng)目并打包的詳細(xì)流程,需要的朋友可以參考下2023-03-03解決npm?install版本不匹配問(wèn)題:?npm?ERR!?code?ETARGET?npm?ERR!?
這篇文章主要介紹了如何解決npm?install版本不匹配問(wèn)題:?npm?ERR!?code?ETARGET?npm?ERR!?notarget?No?matching?version?found?for,文中給出了詳細(xì)的解決方法,需要的朋友可以參考下2024-02-02Node.js全局可用變量、函數(shù)和對(duì)象示例詳解
JavaScript中有一個(gè)特殊的對(duì)象,稱(chēng)為全局對(duì)象(Global Object),它及其所有屬性都可以在程序的任何地方訪(fǎng)問(wèn),即全局變量,下面這篇文章主要給大家介紹了關(guān)于Node.js全局可用變量、函數(shù)和對(duì)象的相關(guān)資料,需要的朋友可以參考下2023-03-03Nodejs使用archiver-zip-encrypted庫(kù)加密壓縮文件時(shí)報(bào)錯(cuò)(解決方案)
這篇文章主要介紹了Nodejs使用archiver-zip-encrypted庫(kù)加密壓縮文件時(shí)報(bào)錯(cuò),朋友朋友在測(cè)試過(guò)程中都出現(xiàn)過(guò)異常,下面小編把問(wèn)題過(guò)程分析腳本之家平臺(tái),需要的朋友可以參考下2019-11-11node.js中的fs.readFileSync方法使用說(shuō)明
這篇文章主要介紹了node.js中的fs.readFileSync方法使用說(shuō)明,本文介紹了fs.readFileSync的方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下2014-12-12node.js中的url.parse方法使用說(shuō)明
這篇文章主要介紹了node.js中的url.parse方法使用說(shuō)明,本文介紹了url.parse的方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下2014-12-12nodejs獲取本機(jī)內(nèi)網(wǎng)和外網(wǎng)ip地址的實(shí)現(xiàn)代碼
這篇文章主要介紹了nodejs獲取本機(jī)內(nèi)網(wǎng)和外網(wǎng)ip地址的實(shí)現(xiàn)代碼,需要的朋友可以參考下2014-06-06node.js中的console.time方法使用說(shuō)明
這篇文章主要介紹了node.js中的console.time方法使用說(shuō)明,本文介紹了console.time的方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下2014-12-12