国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

Node.js模擬發起http請求從異步轉同步的5種用法

2024-05-06 16:46:13
字體:
來源:轉載
供稿:網友

使用 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武林網網站的支持!


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宝丰县| 治县。| 凌海市| 德保县| 鹤岗市| 辉南县| 平乐县| 繁峙县| 乌拉特中旗| 黄浦区| 吉木萨尔县| 蒲江县| 海盐县| 大余县| 香港 | 九江县| 昌江| 台北市| 丰都县| 营口市| 麻城市| 凉山| 孝义市| 龙门县| 银川市| 诸暨市| 滨州市| 新干县| 靖安县| 锦州市| 湟中县| 吴旗县| 叙永县| 龙海市| 富锦市| 宝坻区| 土默特左旗| 平远县| 平远县| 尖扎县| 高雄县|