国产探花免费观看_亚洲丰满少妇自慰呻吟_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 );}            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 沁源县| 紫阳县| 镇沅| 绍兴市| 德令哈市| 来安县| 泗洪县| 漳州市| 黄石市| 克拉玛依市| 潞西市| 宝坻区| 河南省| 保山市| 和政县| 曲靖市| 新建县| 望谟县| 建德市| 山东| 泗阳县| 兴文县| 高要市| 远安县| 安阳市| 双桥区| 泸水县| 宿松县| 尚义县| 株洲市| 建阳市| 郎溪县| 乌恰县| 攀枝花市| 泸西县| 唐河县| 祁东县| 汽车| 昌都县| 贡山| 甘肃省|