今天在scott老師的帶領下學習了一下nodeJS基礎的一些東西,更激動的是學習了簡單的灌水小程序,於是記錄如下。
首先我們需要調用http模塊
var http = require('http')
接着需要使用把請求內容轉換成發送的內容碼,需要用到querystring 模塊
var querystring = require('querystring')
因爲我們需要用到http模塊的request。因此先來介紹一下這個函數唄
http.request(options[,callback])
接受兩個參數
options 和callback 。 callback可以接受遠程回覆的response對象,然後我們就可以在回調函數中對response進行一定操作。
options可以是字符串也可以是對象。如果是字符串的話會被url.parse解析爲對象。
options常用參數
參數 | 含義 |
---|---|
host | 將要請求的服務器域名或者IP |
hostname: | host的別名 |
port | 遠程端口 |
localAddress | 本地接口 |
method | 指定請求方法。默認是get |
path | 請求的路徑,默認是根目錄。如果有查詢的字符串就需要追加參數 |
headers | 包含請求頭的對象 |
auth | 認證,一般是User+psw |
agent | 控制代理行爲 |
keepAlive | 保持套接字在未來能夠用於其他請求,默認false。 |
上面的參數不需要都填寫完,因爲很多都會默認給的。
技術灌水
哈哈,可以來到正題啦。
首先我們需要向服務器發起請求,那麼具體這個請求是怎麼發的呢?
當我們在評論框輸入評論並點擊發表,chrome瀏覽器就會發起一次post,如果我們模擬這個post的話就可以實現程序中的評論。
所以我們用到之前提到的http.request()方法。那麼我們就需要指定具體的options參數。參數如下:
var options = {
host:'www.imooc.com',
port:"80",
path:'/course/docomment',
method:'POST',
headers:{
//看下文
}
}
查看headers,使用chrome的network就可以看到具體的requestHeaders。如下圖
然後把Request Headers中的內容全部拷貝到代碼中,(圖中的我是隨便找的一個,只是大致看什麼樣子)如下
var options = {
host:'www.imooc.com',
port:"80",
path:'/course/docomment',
method:'POST',
headers:{
Accept : 'application/json, text/javascript, */*; q=0.01',
'Accept-Encoding' : ' gzip, deflate',
'Accept-Language' : ' zh-CN,zh;q=0.8',
Connection : ' keep-alive',
'Content-Length' : postData.length,
'Content-Type' : ' application/x-www-form-urlencoded; charset=UTF-8',
Cookie : 'imooc_uuid=36390c46-3c81-4d3e-96da-ba51f5329344; imooc_isnew_ct=1474461380; loginstate=1; apsid=MwY2RmZGNiMjdmNjlhMjUzMDFjMjUzNWQzMDgxOWUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMTE3NDc0MwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABxaXl1X3NqdHVAMTYzLmNvbQAAAAAAAAAAAAAAAAAAAGZmYWYxMTg5ZTk5ZjdkZDlkOTZmNGFjZTZkMDY2MWRjJH%2FiVyR%2F4lc%3DZm; last_login_username=qiyu_sjtu%40163.com; PHPSESSID=fe42eaq1t9kkmgrf3vll6raco1; jwplayer.qualityLabel=超清; IMCDNS=0; Hm_lvt_f0cfcccd7b1393990c78efdeebff3968=1474958457,1475248865,1475278901,1475324860; Hm_lpvt_f0cfcccd7b1393990c78efdeebff3968=1475327045; imooc_isnew=2; cvde=57efabbaa8136-21',
Host:'www.imooc.com',
Origin:'http://www.imooc.com',
Referer:'http://www.imooc.com/video/8837',
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.116 Safari/537.36',
'X-Requested-With':'XMLHttpRequest'
}
}
好啦,我們可以發起請求啦!
var req = http.request(options,function(res){
console.log('Status'+res.statusCode)
console.log('headers'+JSON.stringify(res.headers))
res.on('data',function(chunk){
console.log(Buffer.isBuffer(chunk));
console.log(typeof chunk);
})
res.on('end',function(){
console.log("建立連接!");
})
})
req.on('error',function(e){
console.log("Error:"+e.message);
})
注意res就是服務器返回的response對象,我們就可以獲得他的屬性啦,我們可以看statusCode(狀態碼)知道是否連接哦
然後我們再發送數據
var postData = querystring.stringify({
'content':'6666666',//評論內容
'cid':348//課程號
})
req.write(postData)
req.end()
res.end()表明完成了這個請求~
好的,到此爲止我們就完成啦!感覺還挺有趣的