從零開始學(xué)習(xí)Node.js系列教程一:http get和post用法分析
本文實(shí)例講述了Node.js中http get和post用法。分享給大家供大家參考,具體如下:
httpserverrequestget.js
/* 獲取GET請求內(nèi)容 由于GET請求直接被嵌入在路徑中,URL是完整的請求路徑,包括了?后面的部分,因此你可以手動解析后面的內(nèi)容作為GET請求的參數(shù)。 node.js中url模塊中的parse函數(shù)提供了這個(gè)功能。 */ var http = require('http'); var url = require('url'); var util = require('util'); http.createServer(function(req, res){ res.writeHead(200, {'Content-Type': 'text/plain'}); res.end(util.inspect(url.parse(req.url, true))); }).listen(3000); //在瀏覽器中訪問http://localhost:3000/user?name=joey&email=joey@joey.com 然后查看返回結(jié)果
httpserverrequestpost.js
/* POST請求的內(nèi)容全部的都在請求體中,http.ServerRequest并沒有一個(gè)屬性內(nèi)容為請求體,原因是等待請求體傳輸可能是一件耗時(shí)的工作, 比如上傳文件,而很多時(shí)候我們可能并不需要理會請求體的內(nèi)容,惡意的POST請求會大大消耗服務(wù)器的資源,所有node.js默認(rèn)是不會解析請求體的, 當(dāng)你需要的時(shí)候,需要手動來做。 */ var http = require('http'); var querystring = require('querystring'); var util = require('util'); http.createServer(function(req, res){ var post = ''; //定義了一個(gè)post變量,用于暫存請求體的信息 req.on('data', function(chunk){ //通過req的data事件監(jiān)聽函數(shù),每當(dāng)接受到請求體的數(shù)據(jù),就累加到post變量中 post += chunk; }); req.on('end', function(){ //在end事件觸發(fā)后,通過querystring.parse將post解析為真正的POST請求格式,然后向客戶端返回。 post = querystring.parse(post); res.end(util.inspect(post)); }); }).listen(3000);
注意:不要在真正的生產(chǎn)應(yīng)用中使用上面這種簡單的方法來獲取POST請求,因?yàn)樗袊?yán)重的效率問題和安全問題,這只是一個(gè)幫你理解的示例。
知識擴(kuò)展:util.inherits繼承
/* util.inherits 定義了一個(gè)基礎(chǔ)對象Base和一個(gè)繼承自Base的Sub,Base有三個(gè)在構(gòu)造函數(shù)內(nèi)定義的屬性和一個(gè)原型中定義的函數(shù),通過util.inherits實(shí)現(xiàn)繼承 注意,Sub僅僅繼承了Base在原型中定義的函數(shù),而構(gòu)造函數(shù)內(nèi)部創(chuàng)造的base屬性和sayHello函數(shù)都沒有被Sub繼承。 */ var util = require('util'); function Base(){ this.name = 'base'; this.base = 1991; this.sayHello = function(){ console.log('Hello ' + this.name); }; } Base.prototype.showName = function(){ console.log(this.name); }; function Sub(){ this.name = 'sub'; } util.inherits(Sub, Base); var objBase = new Base(); objBase.showName(); objBase.sayHello(); console.log(objBase); var objSub = new Sub(); objSub.showName(); //objSub.sayHello(); console.log(objSub);
希望本文所述對大家nodejs程序設(shè)計(jì)有所幫助。
相關(guān)文章
利用Node轉(zhuǎn)換Excel成JSON的詳細(xì)步驟
最近工作中遇到一個(gè)需求,大致需求就是將Excel文件在導(dǎo)入時(shí)解析為json格式轉(zhuǎn)換數(shù)據(jù)結(jié)構(gòu)再傳輸給后臺,下面這篇文章主要給大家介紹了關(guān)于如何利用Node轉(zhuǎn)換Excel成JSON的詳細(xì)步驟,需要的朋友可以參考下2022-11-11node實(shí)現(xiàn)封裝一個(gè)圖片拼接插件
這篇文章主要介紹了node實(shí)現(xiàn)封裝一個(gè)圖片拼接插件,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-08-08Express實(shí)現(xiàn)定時(shí)發(fā)送郵件的示例代碼
在開發(fā)中我們有時(shí)候需要每隔?一段時(shí)間發(fā)送一次電子郵件,或者在某個(gè)特定的時(shí)間進(jìn)行發(fā)送郵件,無需手動去操作,基于這樣的情況下我們需要用到了定時(shí)任務(wù)。本文就來用Express實(shí)現(xiàn)定時(shí)發(fā)送郵件吧2023-04-04Node.js里面的內(nèi)置模塊和自定義模塊的實(shí)現(xiàn)
這篇文章主要介紹了Node.js里面的內(nèi)置模塊和自定義模塊的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05