Nodejs Request使用介紹
這篇就先介紹一個Node.js的模塊——request。有了這個模塊,http請求變的超簡單。
使用超簡單
Request使用超簡單,同時支持https和重定向。
var request = require('request');
request('http://www.google.com', function (error, response, body) {
if (!error && response.statusCode == 200) {
console.log(body) // 打印google首頁
}
}) 流
任何響應都可以輸出到文件流。
request('http://google.com/doodle.png').pipe(fs.createWriteStream('doodle.png')) 反過來,也可以將文件傳給PUT或POST請求。未提供header的情況下,會檢測文件后綴名,在PUT請求中設置相應的content-type。
fs.createReadStream('file.json').pipe(request.put('http://mysite.com/obj.json')) 請求也可以pipe給自己。這種情況下會保留原content-type和content-length。
request.get('http://google.com/img.png').pipe(request.put('http://mysite.com/img.png')) 表單
request支持application/x-www-form-urlencoded和multipart/form-data實現表單上傳。
x-www-form-urlencoded很簡單:
request.post('http://service.com/upload', {form:{key:'value'}}) 或者:
request.post('http://service.com/upload').form({key:'value'}) 使用multipart/form-data不用操心設置header之類的瑣事,request會幫你解決。
var r = request.post('http://service.com/upload')
var form = r.form()
form.append('my_field', 'my_value')
form.append('my_buffer', new Buffer([1, 2, 3]))
form.append('my_file', fs.createReadStream(path.join(__dirname, 'doodle.png'))
form.append('remote_file', request('http://google.com/doodle.png')) HTTP認證
request.get('http://some.server.com/').auth('username', 'password', false); 或
request.get('http://some.server.com/', {
'auth': {
'user': 'username',
'pass': 'password',
'sendImmediately': false
}
}); sendImmediately,默認為真,發送一個基本的認證header。設為false之后,收到401會重試(服務器的401響應必須包含WWW-Authenticate指定認證方法)。
sendImmediately為真時支持Digest認證。
OAuth登錄
// 推ter OAuth
var qs = require('querystring')
, oauth =
{ callback: 'http://mysite.com/callback/'
, consumer_key: CONSUMER_KEY
, consumer_secret: CONSUMER_SECRET
}
, url = 'https://api.推ter.com/oauth/request_token'
;
request.post({url:url, oauth:oauth}, function (e, r, body) {
// Ideally, you would take the body in the response
// and construct a URL that a user clicks on (like a sign in button).
// The verifier is only available in the response after a user has
// verified with 推ter that they are authorizing your app.
var access_token = qs.parse(body)
, oauth =
{ consumer_key: CONSUMER_KEY
, consumer_secret: CONSUMER_SECRET
, token: access_token.oauth_token
, verifier: access_token.oauth_verifier
}
, url = 'https://api.推ter.com/oauth/access_token'
;
request.post({url:url, oauth:oauth}, function (e, r, body) {
var perm_token = qs.parse(body)
, oauth =
{ consumer_key: CONSUMER_KEY
, consumer_secret: CONSUMER_SECRET
, token: perm_token.oauth_token
, token_secret: perm_token.oauth_token_secret
}
, url = 'https://api.推ter.com/1/users/show.json?'
, params =
{ screen_name: perm_token.screen_name
, user_id: perm_token.user_id
}
;
url += qs.stringify(params)
request.get({url:url, oauth:oauth, json:true}, function (e, r, user) {
console.log(user)
})
})
}) 定制HTTP header
User-Agent之類可以在options對象中設置。在下面的例子中,我們調用github API找出某倉庫的收藏數和派生數。我們使用了定制的User-Agent和https.
var request = require('request');
var options = {
url: 'https://api.github.com/repos/mikeal/request',
headers: {
'User-Agent': 'request'
}
};
function callback(error, response, body) {
if (!error && response.statusCode == 200) {
var info = JSON.parse(body);
console.log(info.stargazers_count +"Stars");
console.log(info.forks_count +"Forks");
}
}
request(options, callback); cookies
默認情況下,cookies是禁用的。在defaults或options將jar設為true,使后續的請求都使用cookie.
var request = request.defaults({jar: true})
request('http://www.google.com', function () {
request('http://images.google.com')
}) 通過創建request.jar()的新實例,可以使用定制的cookie,而不是request全局的cookie jar。
var j = request.jar()
var request = request.defaults({jar:j})
request('http://www.google.com', function () {
request('http://images.google.com')
}) 或者
var j = request.jar()
var cookie = request.cookie('your_cookie_here')
j.setCookie(cookie, uri, function (err, cookie){})
request({url: 'http://www.google.com', jar: j}, function () {
request('http://images.google.com')
}) 注意,setCookie至少需要三個參數,最后一個是回調函數。
項目主頁
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!