NodeJS實現網站評論

今天在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()表明完成了這個請求~
好的,到此爲止我們就完成啦!感覺還挺有趣的

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章