使用Node.js
模擬發起http
請求很經常使用的,可是因爲Node
模塊(原生和第三方庫)提供裏面的方法都是異步,對於不少場景下應用很麻煩,不如同步來的方便。下面總結了幾個常見的庫API
從異步轉同步的幾種方法。模塊有:request
, request-promise
, request-promise-native
, request-promise-any
json
PS:Node的版本>=8.0.0 爲了使用 Async / Await
PS: 這裏加入auth
字段是爲了須要用戶名和密碼登陸的應用的請求 ,好比rabbitmq
,不須要登陸的頁面能夠去掉這個參數。promise
使用原生模塊 util
, 利用其 promisify
API
, 代碼示例以下:異步
const request = require('request'); const util = require('util'); var url = "https://www.baidu.com/"; const getPromise = util.promisify(request.get); // PS: 這裏加入auth 字段是爲了須要用戶名和密碼登陸的應用的請求 ,好比rabbitmq ,不須要登陸的頁面能夠去掉這個參數。 //1: 原生寫法 無auth 參數 getPromise(url).then((value)=>{ console.log("value" , value ); }).catch((err)=>{ console.log("err" , err ); }); //2: 原生寫法 有auth 參數 getPromise(url , {'auth' : { 'user' : 'xx', 'pass' : 'xx', 'sendImmediately' : 'false', }}).then((value)=>{ console.log("value" , value ); }).catch((err)=>{ console.log("err" , err ); }); // 第二種寫法 async/await // 我的最建議使用這種 , 只使用util 和 request 。 async function handle(){ let result = await getPromise(url , {'auth' : { 'user' : 'xx', 'pass' : 'xx', 'sendImmediately' : 'false', }}); // 能夠加入 try catch 捕獲異常 也能夠加 .catch() console.log("result" , result.); } handle(); PS: `auth` 參數的用法參考[連接][1] , 在異步變同步中 不能使用 `request.get().auth()` 寫法。
使用模塊 request-promise-native
, request-promise-native
是使用 native Promise
寫的,查看源碼能夠看到繼承自 Request
模塊 , 代碼示例以下:async
// 再也不寫 原生示例 then()鏈的那種,參考第一個示例便可 //get 請求示例 const rpn = require('request-promise-native'); var url = "https://www.baidu.com/"; async function useRequestPromiseNative(){ // options 裏面的參數能夠去看request的源碼 查看其index.d.ts 文件裏面的 interface CoreOptions 裏面有全部的參數。 let options = { method: 'GET', uri: url, auth : { 'user' : 'xx', 'pass' : 'xx', 'sendImmediately' : 'false', } }; let rpnbody = await rpn(options); console.log("rpnbody" , rpnbody ); } useRequestPromiseNative(); // post 示例 const rpn = require('request-promise-native'); var url = "https://www.baidu.com/"; async function useRequestPromiseNative(){ let options = { method: 'POST', uri: url, body: { // 這裏定義你的body參數 } json: true, // 這個看你的參數而定 }; let rpnbody = await rpn(options); console.log("rpnbody" , rpnbody ); } useRequestPromiseNative();
使用模塊 request-promise
, request-promise
是基於 bluebird
寫的, 查看源碼能夠看到繼承自 Request
模塊 , 代碼示例以下:post
// 再也不寫post 示例 const rp = require('request-promise'); var url = "https://www.baidu.com/"; async function useRequestPromise(){ let options = { method: 'GET', uri: url, auth : { //能夠拿掉 'user' : 'xx', 'pass' : 'xx', 'sendImmediately' : 'false', } }; let rpbody = await rp(options); console.log("rpnbody" , rpbody ); } useRequestPromise();
使用模塊 request-promise-any
, request-promise-any
也是基於 request
寫的, 代碼示例以下:ui
// 再也不寫post 示例 const rpa = require('request-promise-any'); var url = "https://www.baidu.com/"; async function useRequestPromiseAny(){ let options = { method: 'GET', uri: url, auth : { 'user' : 'xx', 'pass' : 'xx', 'sendImmediately' : 'false', } }; let rpabody = await rpa(options); console.log("rpabody" , rpabody ); } useRequestPromiseAny();
使用模塊 bluebird
, 利用其 promisifyAll
API
轉成Promise
, 代碼示例以下:url
const Promise = require('bluebird'); const request = require('request'); var url = "https://www.baidu.com/"; Promise.promisifyAll(request, { suffix: 'SC' }); //suffix 自定義 get --> getSC async function usebluebird(){ let result = await request.getSC(url , {'auth' : { 'user' : 'xx', 'pass' : 'xxx', 'sendImmediately' : 'false', }}); console.log("result" , result); } usebluebird()
上面總結了5種使用方法,其實要說也不止5種了,你們根據本身須要來選擇。code