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

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 15:29:28
字體:
來源:轉載
供稿:網友

使用 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 );}            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 吴江市| 兴安县| 盘山县| 商丘市| 长宁县| 昌邑市| 德化县| 额敏县| 台中县| 通州区| 静乐县| 内江市| 开化县| 昆山市| 江山市| 宜州市| 富蕴县| 天柱县| 涡阳县| 闵行区| 屏东市| 双鸭山市| 漠河县| 江源县| 永康市| 松滋市| 余江县| 黑水县| 长阳| 沾化县| 北安市| 温泉县| 儋州市| 神池县| 怀化市| 陇南市| 鹿邑县| 十堰市| 烟台市| 武强县| 九龙县|