资讯专栏INFORMATION COLUMN

Node.js模拟发起http请求从异步转同步的5种方法

TalkingData / 905人阅读

摘要:使用模拟发起请求很常用的但是由于模块原生和第三方库提供里面的方法都是异步,对于很多场景下应用很麻烦,不如同步来的方便。下面总结了几个常见的库从异步转同步的几种方法。可以加入捕获异常也可以加参数的用法参考链接在异步变同步中不能使用写法。

使用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()` 写法。

第二种

使用模块 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 --> getSC

async function usebluebird(){

    let result = await request.getSC(url , {"auth" : {
        "user" : "xx",
        "pass" : "xxx",
        "sendImmediately" : "false",
    }});
    console.log("result" , result);
}

usebluebird()

上面总结了5种使用方法,其实要说也不止5种了,大家根据自己需要来选择。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/97767.html

相关文章

  • ()JavaScript:同步异步和事件循环

    摘要:事件循环事件循环是指主线程重复从消息队列中取消息执行的过程。事件触发时,表示异步任务完成,会将事件监听器函数封装成一条消息放到消息队列中,等待主线程执行。 一. 单线程 我们常说JavaScript是单线程的。 所谓单线程,是指在JS引擎中负责解释和执行JavaScript代码的线程只有一个。不妨叫它主线程。 但是实际上还存在其他的线程。例如:处理AJAX请求的线程、处理DOM事件的线...

    android_c 评论0 收藏0
  • node.js异步IO 第一篇

    摘要:给出了解决方案就是单线程,远离线程锁,状态同步的问题,使用异步让单线程远离阻塞,高效利用。而实际上的异步是采用了线程池技术,发起异步时,把操作扔到线程池里面执行,然后主线程继续执行其他操作,执行完毕通过线程间通信通知主线程,主线程执行回调。 异步IO,事件驱动,单线程构成了node的基调,为什么异步IO在node中如此重要呢? 我们先来说一下异步的概念,异步常见于前端开发,例如ajax...

    feng409 评论0 收藏0
  • 最近遇到前端面试题(2017.03.08更新版)

    摘要:通过管理组件通信通过驱动视图比较差异进行更新操作作者第七页链接来源知乎著作权归作者所有,转载请联系作者获得授权。达到无刷新的效果。对象的状态不受外界影响。对象代表一个异步操作,有三种状态进行中已完成,又称和已失败。 以下问题解释非本人原创,是根据面试经验整理后觉得更容易理解的解释版本,欢迎补充。 一. 输入url后的加载过程 从输入 URL 到页面加载完成的过程中都发生了什么 计算机...

    Nosee 评论0 收藏0
  • 最近遇到前端面试题(2017.03.08更新版)

    摘要:通过管理组件通信通过驱动视图比较差异进行更新操作作者第七页链接来源知乎著作权归作者所有,转载请联系作者获得授权。达到无刷新的效果。对象的状态不受外界影响。对象代表一个异步操作,有三种状态进行中已完成,又称和已失败。 以下问题解释非本人原创,是根据面试经验整理后觉得更容易理解的解释版本,欢迎补充。 一. 输入url后的加载过程 从输入 URL 到页面加载完成的过程中都发生了什么 计算机...

    刘东 评论0 收藏0

发表评论

0条评论

TalkingData

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<