node.js學(xué)習(xí)筆記之http模塊

本文基于Node.js v6.9.4,詳情請參考官網(wǎng)API

1. 創(chuàng)建服務(wù)器http.createServer

方式一和方式二效果一樣,方式一只不過是在創(chuàng)建服務(wù)器時,自動綁定了'request'事件

// 方式一 http.createServer([requestListener])
/*
 * [requestListener(req, res)] 用戶請求后回調(diào)函數(shù),有兩個參數(shù),req請求;res響應(yīng)
 * @return http.Server 返回一個http.Server實例
 */
var server = http.createServer((req, res) => {
    res.writeHeader(200,{'Content-Type':'text/plain'});
    res.end('hello world');
})

 // 方式二 new http.Server()
 var server = new http.Server();
 server.on('request', (req, res){
    res.writeHeader(200,{'Content-Type':'text/plain'});
        res.end('hello world');
 })

2. http.Server

上例中的server就是http.Server的一個實例
此模塊會觸發(fā)以下事件

  • checkContinue 當(dāng)請求頭Expect的值是 100-continue時觸發(fā)
  • checkExpectation 當(dāng)請求頭Expect的值不是 100-continue時觸發(fā)
  • clientError 客戶端觸發(fā)了一個error錯誤
    function(exception){}
  • close 關(guān)閉服務(wù)器時觸發(fā)
function(errno){}
  • connect 如果客戶端發(fā)起connect請求時觸發(fā)
// 當(dāng)一個新的TCP stream建立后發(fā)送此消息,stream是一個net.Stream的對象,通常用戶不會訪問/使用這個事件
function(stream){}
  • connection 新的TCP流建立時觸發(fā)
  • request 客戶端請求事件
/*
 * req是http.ServerRequest的一個實例,
 * res是http.ServerResponse的一個實例
 */
function(req, res){}
  • upgrade 每當(dāng)一個客戶端請求一個http upgrade 時候發(fā)出此消息
/*
* socket是在服務(wù)器與客戶端之間連接用的網(wǎng)絡(luò)socket
* head 是Buffer 的一個實例
*/
function(req, socket, head){}

3. http.request(options[,callback])

客戶端向http服務(wù)器發(fā)起請求

/*
 * options {hostname: string, port:number, method:string, path:string, handers:{}}
 *  hostname 服務(wù)器域名或IP地址
 *  port 端口
 *  method 請求方式,有GET、POST、INPUT、DELETE、CONNECT,默認(rèn)為GET
 *  path: 請求地址,可包含查詢字符串及可能村長的錨點,例如'/index.html?page=12'
 *  handers: 一個包含請求頭的對象
 *  @return http.ClientRequest 返回http.ClientRequest的實例
 */
 var options = {
        hostname : 'www.baidu.com',
        port : 80,
        method : 'GET',
        path : '/upload',
        handers:{
            'Connection':'keep-alive', // 通知Node此鏈接保持到下一次請求
            'Content-length': 1000,    // 設(shè)置請求主體字節(jié)數(shù)
            'Expect':'100-continue'
        }
 }
 var req = http.request(options, (res) => {})

4. http.get(options,callback)

http.get是http.request的簡化版,唯一的區(qū)別在于http.get自動將請求方法設(shè)為了GET請求,同時不需要手動調(diào)用req.end()

var http = require('http');
http.createServer( (req, res) => {

}).listen(3000);

http.get('http://www.baidu.com/index.html', (res) => {
    console.log('get response Code:'+ res.statusCode);
}).on('error', (e) => {
    console.log('錯誤:'+ e.message);
})

5. http.ClientRequest

http.ClientRequest 是http.request或者h(yuǎn)ttp.get返回產(chǎn)生的對象,表示一個已經(jīng)產(chǎn)生而且正在進(jìn)行的http請求,提供一個response事件,也就是我們使用http.get和http.request方法中的回調(diào)函數(shù)所綁定的對象,我們可以顯示的綁定這個事件的監(jiān)聽函數(shù)。

var http = require('http');

var options = {
    hostname: 'www.baidu.com',
    port:'8080'
}

// 這里的req就是http.ClientRequest的一個實例,注意與http.IncomingMessage的區(qū)別
var req = http.request(options);
req.on('response', function(res){
    res.setEncoding('utf-8');
    res.on('data', function(chunk){
        console.log(chunk.toString())
    });
    console.log(res.statusCode);
})

req.on('error', function(err){
    console.log(err.message);
});
req.end();

http.ClientRequest也提供了write和end函數(shù),用于向服務(wù)器發(fā)送請求體,通常用于POST、PUT等操作,所有的寫操作都必須調(diào)用end函數(shù)來通知服務(wù)器,否則請求無效。


作為回調(diào)參數(shù)使用的對象

6. http.ServerResponse

http.ServerResponse是服務(wù)器返回給客戶端的信息,一般由http.Server的request事件發(fā)送,并作為第二個參數(shù)傳遞,它有三個重要的成員函數(shù),用戶返回響應(yīng)頭、響應(yīng)內(nèi)容已經(jīng)結(jié)束請求。

// 這里的res就是http.ServerResponse的一個實例
http.createServer( (req, res) => {})

6.1 res.writeHead(statusCode[,headers])

向用戶發(fā)送響應(yīng)頭,該函數(shù)在一個請求中最多調(diào)用一次,如果不調(diào)用,則自動生成一個響應(yīng)頭

6.2 res.write(data[,encoding])

向用戶發(fā)送響應(yīng)內(nèi)容,data是發(fā)送的內(nèi)容,encoding是編碼格式

6.3 res.end(data[,encoding])

結(jié)束響應(yīng),該函數(shù)必須被調(diào)用一次

7. http.IncomingMessage

http.IncomingMessage是HTTP請求的信息,是后端開發(fā)著最關(guān)注的內(nèi)容,一般由http.Serve的request事件發(fā)送,并作為第一個參數(shù)傳遞。

// 這里的req就是http.IncomingMessage的一個實例
var http = require('http')
http.createServer( (req, res) => {})
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,936評論 6 535
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,744評論 3 421
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,879評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,181評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 71,935評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,325評論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,384評論 3 443
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,534評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,084評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,892評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,067評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,623評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,322評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,735評論 0 27
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,990評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,800評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 48,084評論 2 375

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