基于node.js項目计盒,教你如何正確發(fā)送HTTP(GET,POST)請求

發(fā)送POST請求,相比GET會有些蛋疼藏杖,因為Node.js(目前0.12.4)現(xiàn)在還沒有直接發(fā)送POST請求的封裝将塑。發(fā)送GET的話,使用http.get
可以直接傳一個字符串作為URL蝌麸,而http.get
方法就是封裝原始的http.request
方法点寥。發(fā)送POST的話,只能使用原始的http.request
方法来吩,同時因為要設(shè)置HTTP請求頭的參數(shù)敢辩,所以必須傳入一個對象作為http.request
的第一個options
參數(shù)(而不是URL字符串)。另外弟疆,options
參數(shù)中的hostname
需要的是不帶協(xié)議的URL根路徑戚长,子路徑需要在path
屬性單獨設(shè)置。如果hostname
包含了完整的URL怠苔,通常會遇到錯誤:Error: getaddrinfo ENOTFOUND http://www.xxx.com/xxx同廉。
這里可以使用url
Module進行協(xié)助,使用url.parse
返回值的hostname
和path
屬性就可以柑司,測試代碼:

var url = require('url');console.log(url.parse('http://www.mgenware.com/a/b/c'));

輸出:

{ protocol: 'http:', slashes: true, auth: null, host: 'www.mgenware.com', port: null, hostname: 'www.mgenware.com', hash: null, search: null, query: null, pathname: '/a/b/c', path: '/a/b/c', href: 'http://www.mgenware.com/a/b/c' }

OK迫肖,hostname
和path
參數(shù)解決后,然后就是常見POST請求HTTP Header屬性的設(shè)置攒驰,設(shè)置method
為POST
蟆湖,另外如果是模擬HTML <form>
的POST請求的話,Content-Type
應(yīng)當是application/x-www-form-urlencoded
玻粪,最后別忘了Content-Length
隅津,而且,如果Content是字符串的話最好用Buffer.byteLength('字符串', 'utf8')
來獲取字節(jié)長度(而不是直接'字符串'.length
奶段,雖然使用URL編碼的ASCII字符串每個字符是1字節(jié))饥瓷。
然后就是回調(diào)的處理,這個在上篇文章中又講過痹籍,Callback中的第一個res
參數(shù)是執(zhí)行Readable Stream接口的呢铆,通過res
的data
事件來把chunk
存在數(shù)組里,最后在end
事件里使用Buffer.concat
把數(shù)據(jù)轉(zhuǎn)換成完整的Buffer
蹲缠,需要的話棺克,通過Buffer.toString
把Buffer
轉(zhuǎn)換成回應(yīng)的字符串悠垛。
完整代碼(我們使用httpbin.org做POST測試):

var querystring = require('querystring');
var url = require('url');
var http = require('http');
var https = require('https');
var util = require('util');
//POST URL
var urlstr = 'http://httpbin.org/post';
//POST 內(nèi)容
var bodyQueryStr = {name: 'mgen',id: 2345,str: 'hahahahahhaa'};
var contentStr = querystring.stringify(bodyQueryStr);
var contentLen = Buffer.byteLength(contentStr, 'utf8');
console.log(util.format('post data: %s, with length: %d', contentStr, contentLen));
var httpModule = urlstr.indexOf('https') === 0 ? https : http;
var urlData = url.parse(urlstr);
//HTTP請求選項
var opt = {hostname: urlData.hostname,path: urlData.path,method: 'POST',
headers: {'Content-Type': 'application/x-www-form-urlencoded','Content-Length': contentLen}};
//處理事件回調(diào)
var req = httpModule.request(opt, function(httpRes) {var buffers = [];
httpRes.on('data', function(chunk) {buffers.push(chunk);});
httpRes.on('end', function(chunk) {var wholeData = Buffer.concat(buffers);
var dataStr = wholeData.toString('utf8');
console.log('content ' + wholeData);
});
}).on('error', function(err) {console.log('error ' + err);});
//寫入數(shù)據(jù),完成發(fā)送
req.write(contentStr);
req.end();

運行完畢后娜谊,會以字符串輸出HTTP回應(yīng)內(nèi)容确买。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市纱皆,隨后出現(xiàn)的幾起案子湾趾,更是在濱河造成了極大的恐慌,老刑警劉巖派草,帶你破解...
    沈念sama閱讀 221,548評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件搀缠,死亡現(xiàn)場離奇詭異,居然都是意外死亡近迁,警方通過查閱死者的電腦和手機艺普,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,497評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鉴竭,“玉大人歧譬,你說我怎么就攤上這事〔妫” “怎么了瑰步?”我有些...
    開封第一講書人閱讀 167,990評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長祭埂。 經(jīng)常有香客問我面氓,道長兵钮,這世上最難降的妖魔是什么蛆橡? 我笑而不...
    開封第一講書人閱讀 59,618評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮掘譬,結(jié)果婚禮上泰演,老公的妹妹穿的比我還像新娘。我一直安慰自己葱轩,他們只是感情好睦焕,可當我...
    茶點故事閱讀 68,618評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著靴拱,像睡著了一般垃喊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上袜炕,一...
    開封第一講書人閱讀 52,246評論 1 308
  • 那天本谜,我揣著相機與錄音,去河邊找鬼偎窘。 笑死乌助,一個胖子當著我的面吹牛溜在,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播他托,決...
    沈念sama閱讀 40,819評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼掖肋,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了赏参?” 一聲冷哼從身側(cè)響起志笼,我...
    開封第一講書人閱讀 39,725評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎把篓,沒想到半個月后籽腕,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,268評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡纸俭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,356評論 3 340
  • 正文 我和宋清朗相戀三年皇耗,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片揍很。...
    茶點故事閱讀 40,488評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡郎楼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出窒悔,到底是詐尸還是另有隱情呜袁,我是刑警寧澤,帶...
    沈念sama閱讀 36,181評論 5 350
  • 正文 年R本政府宣布简珠,位于F島的核電站阶界,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏聋庵。R本人自食惡果不足惜膘融,卻給世界環(huán)境...
    茶點故事閱讀 41,862評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望祭玉。 院中可真熱鬧氧映,春花似錦、人聲如沸脱货。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,331評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽振峻。三九已至臼疫,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間扣孟,已是汗流浹背烫堤。 一陣腳步聲響...
    開封第一講書人閱讀 33,445評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人塔逃。 一個月前我還...
    沈念sama閱讀 48,897評論 3 376
  • 正文 我出身青樓讯壶,卻偏偏與公主長得像,于是被迫代替她去往敵國和親湾盗。 傳聞我的和親對象是個殘疾皇子伏蚊,可洞房花燭夜當晚...
    茶點故事閱讀 45,500評論 2 359

推薦閱讀更多精彩內(nèi)容