使用 Node.js 模擬發起 http 請求很常用的,但是由于 Node 模塊(原生和第三方庫)提供里面的方法都是異步,對于很多場景下應用很麻煩,不如同步來的方便。下面總結了幾個常見的庫 API 從異步轉同步的幾種方法。模塊有: request , request-promise , request-promise-native , request-promise-any
PS: Node的版本>=8.0.0 為了使用 Async / Await PS: 這里加入 auth 字段是為了需要用戶名和密碼登錄的應用的請求 ,比如 rabbitmq ,不需要登錄的頁面可以去掉這個參數。
第一種
使用原生模塊 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()` 寫法。
第二種
// 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-native , request-promise-native 是使用 native Promise 寫的,查看源碼可以看到繼承自 Request 模塊 , 代碼示例如下:
// 不再寫 原生示例 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 示例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 寫的, 代碼示例如下:
// 不再寫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 , 代碼示例如下:
const Promise = require('bluebird');const request = require('request');var url = "https://www.baidu.com/";Promise.promisifyAll(request, { suffix: 'SC' }); //suffix 自定義 get --> getSCasync function usebluebird(){ let result = await request.getSC(url , {'auth' : {  'user' : 'xx',  'pass' : 'xxx',  'sendImmediately' : 'false', }}); console.log("result" , result);}usebluebird()總結
以上所述是小編給大家介紹的Node.js模擬發起http請求從異步轉同步的5種用法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!
新聞熱點
疑難解答