輕松創(chuàng)建nodejs服務(wù)器(6):作出響應(yīng)
我們接著改造服務(wù)器,讓請求處理程序能夠返回一些有意義的信息。
我們來看看如何實(shí)現(xiàn)它:
1、讓請求處理程序通過onRequest函數(shù)直接返回(return())他們要展示給用戶的信息。
2、讓我們從讓請求處理程序返回需要在瀏覽器中顯示的信息開始。
我們需要將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;
同樣的,請求路由需要將請求處理程序返回給它的信息返回給服務(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)請求無法路由的時候,我們也返回了一些相關(guān)的錯誤信息。
最后,我們需要對我們的server.js進(jìn)行重構(gòu)以使得它能夠?qū)⒄埱筇幚沓绦蛲ㄟ^請求路由返回的內(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)用:
請求http://localhost:8888/start,瀏覽器會輸出“Hello Start”,
請求http://localhost:8888/upload會輸出“Hello Upload”,
而請求http://localhost:8888/foo 會輸出“404 Not found”。
這感覺不錯,下一節(jié)我們要來了解一個概念:阻塞操作。
- 輕松創(chuàng)建nodejs服務(wù)器(10):處理POST請求
- 輕松創(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):一個簡單nodejs服務(wù)器例子
- 零基礎(chǔ)搭建Node.js、Express、Ejs、Mongodb服務(wù)器及應(yīng)用開發(fā)入門
- 用用outlook Express 由于服務(wù)器拒絕接受發(fā)件人的電子郵件地址,這封郵件無法發(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)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07webpack創(chuàng)建項(xiàng)目并打包的詳細(xì)流程記錄
webpack在前端工程領(lǐng)域起到了中流砥柱的作用,理解它的內(nèi)部實(shí)現(xiàn)機(jī)制會對你的工程建設(shè)提供很大的幫助(不論是定制功能還是優(yōu)化打包),下面這篇文章主要給大家介紹了關(guān)于webpack創(chuàng)建項(xiàng)目并打包的詳細(xì)流程,需要的朋友可以參考下2023-03-03解決npm?install版本不匹配問題:?npm?ERR!?code?ETARGET?npm?ERR!?
這篇文章主要介紹了如何解決npm?install版本不匹配問題:?npm?ERR!?code?ETARGET?npm?ERR!?notarget?No?matching?version?found?for,文中給出了詳細(xì)的解決方法,需要的朋友可以參考下2024-02-02Nodejs使用archiver-zip-encrypted庫加密壓縮文件時報(bào)錯(解決方案)
這篇文章主要介紹了Nodejs使用archiver-zip-encrypted庫加密壓縮文件時報(bào)錯,朋友朋友在測試過程中都出現(xiàn)過異常,下面小編把問題過程分析腳本之家平臺,需要的朋友可以參考下2019-11-11node.js中的fs.readFileSync方法使用說明
這篇文章主要介紹了node.js中的fs.readFileSync方法使用說明,本文介紹了fs.readFileSync的方法說明、語法、接收參數(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-06