您好,登錄后才能下訂單哦!
本文實(shí)例講述了Node.js中http get和post用法。分享給大家供大家參考,具體如下:
httpserverrequestget.js
/* 獲取GET請(qǐng)求內(nèi)容 由于GET請(qǐng)求直接被嵌入在路徑中,URL是完整的請(qǐng)求路徑,包括了?后面的部分,因此你可以手動(dòng)解析后面的內(nèi)容作為GET請(qǐng)求的參數(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); //在瀏覽器中訪問(wèn)http://localhost:3000/user?name=joey&email=joey@joey.com 然后查看返回結(jié)果
httpserverrequestpost.js
/* POST請(qǐng)求的內(nèi)容全部的都在請(qǐng)求體中,http.ServerRequest并沒(méi)有一個(gè)屬性內(nèi)容為請(qǐng)求體,原因是等待請(qǐng)求體傳輸可能是一件耗時(shí)的工作, 比如上傳文件,而很多時(shí)候我們可能并不需要理會(huì)請(qǐng)求體的內(nèi)容,惡意的POST請(qǐng)求會(huì)大大消耗服務(wù)器的資源,所有node.js默認(rèn)是不會(huì)解析請(qǐng)求體的, 當(dāng)你需要的時(shí)候,需要手動(dòng)來(lái)做。 */ var http = require('http'); var querystring = require('querystring'); var util = require('util'); http.createServer(function(req, res){ var post = ''; //定義了一個(gè)post變量,用于暫存請(qǐng)求體的信息 req.on('data', function(chunk){ //通過(guò)req的data事件監(jiān)聽函數(shù),每當(dāng)接受到請(qǐng)求體的數(shù)據(jù),就累加到post變量中 post += chunk; }); req.on('end', function(){ //在end事件觸發(fā)后,通過(guò)querystring.parse將post解析為真正的POST請(qǐng)求格式,然后向客戶端返回。 post = querystring.parse(post); res.end(util.inspect(post)); }); }).listen(3000);
注意:不要在真正的生產(chǎn)應(yīng)用中使用上面這種簡(jiǎn)單的方法來(lái)獲取POST請(qǐng)求,因?yàn)樗袊?yán)重的效率問(wèn)題和安全問(wèn)題,這只是一個(gè)幫你理解的示例。
知識(shí)擴(kuò)展:util.inherits繼承
/* util.inherits 定義了一個(gè)基礎(chǔ)對(duì)象Base和一個(gè)繼承自Base的Sub,Base有三個(gè)在構(gòu)造函數(shù)內(nèi)定義的屬性和一個(gè)原型中定義的函數(shù),通過(guò)util.inherits實(shí)現(xiàn)繼承 注意,Sub僅僅繼承了Base在原型中定義的函數(shù),而構(gòu)造函數(shù)內(nèi)部創(chuàng)造的base屬性和sayHello函數(shù)都沒(méi)有被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);
希望本文所述對(duì)大家nodejs程序設(shè)計(jì)有所幫助。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。