Node.js   发布时间:2022-04-24  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Node.js模拟发起http请求从异步转同步的5种方法大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
@H_618_0@
@H_618_0@

使用Node.js@H_502_8@模拟发起http@H_502_8@请求很常用的,但是由于Node@H_502_8@模块(原生和第三方库)提供里面的方法都是异步,对于很多场景下应用很麻烦,不如同步来的方便。下面总结了几个常见的库API@H_502_8@从异步转同步的几种方法。模块有:request@H_502_8@,request-promise@H_502_8@,request-promise-native@H_502_8@,request-promise-any@H_502_8@

PS:Node的版本>=8.0.0 为了使用 Async / Await@H_502_8@
PS: 这里加入auth@H_502_8@ 字段是为了需要用户名和密码登录的应用的请求 ,比如rabbitmq@H_502_8@,不需要登录页面可以去掉这个参数。

第一种

使用原生模块 util@H_502_8@,利用其 promisify@H_502_8@ API@H_502_8@ , 代码示例如下:

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",err );
});

// 第二种写法   async/await

// 个人最建议使用这种 , 只使用util 和 request 。

async function handle(){

    let result = await getPromise(url,{‘auth‘ : {
        ‘user‘ : ‘xx‘,}});
    // 可以加入 try catch 捕获异常  也可以加 .catch()
    console.log("result",result.);
}

handle();

PS: `auth` 参数的用法[链接][1],在异步变同步中 不能使用  `request.get().auth()` 写法。

第二种

使用模块 request-promise-native@H_502_8@,request-promise-native@H_502_8@是使用 native Promise@H_502_8@ 写的,查看源码可以看到继承自 request@H_502_8@ 模块 , 代码示例如下:

// 不再写 原生示例  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‘,}
      };
    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‘,body: {    // 这里定义你的body参数
        }
        json: true,// 这个看你的参数而定
      };
    let  rpnbody = await rpn(options);       
    
    console.log("rpnbody",rpnbody );
}
userequestPromiseNative();

第三种

使用模块 request-promise@H_502_8@,request-promise@H_502_8@是基于 bluebird@H_502_8@ 写的, 查看源码可以看到继承自 request@H_502_8@ 模块 , 代码示例如下:

// 不再写post 示例

const rp  = require(‘request-promise‘);
var url = "https://www.baidu.com/";
async function userequestPromise(){
    let options = {
        method: ‘GET‘,auth : {      //可以拿掉
            ‘user‘ : ‘xx‘,}
      };
    let  rpbody = await rp(options);       
    console.log("rpnbody",rpbody );
}

userequestPromise();

第四种

使用模块 request-promise-any@H_502_8@,request-promise-any@H_502_8@也是基于 request@H_502_8@ 写的, 代码示例如下:

// 不再写post 示例

const rpa = require(‘request-promise-any‘);
var url = "https://www.baidu.com/";
async function userequestPromiseAny(){
    let options = {
        method: ‘GET‘,}
      };
    let  rpabody = await rpa(options);       
    console.log("rpabody",rpabody );
}

userequestPromiseAny();

第五种

使用模块 bluebird@H_502_8@,利用其 promisifyAll@H_502_8@ API@H_502_8@ 转成Promise@H_502_8@ , 代码示例如下:

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,‘pass‘ : ‘XXX‘,}});
    console.log("result",result);
}

usebluebird()

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

来源:https://segmentfault.com/a/1190000016402949

@H_618_0@

大佬总结

以上是大佬教程为你收集整理的Node.js模拟发起http请求从异步转同步的5种方法全部内容,希望文章能够帮你解决Node.js模拟发起http请求从异步转同步的5种方法所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:5httpjs发起同步异步方法模拟请求
猜你在找的Node.js相关文章
其他相关热搜词更多
phpJavaPython程序员load如何string使用参数jquery开发安装listlinuxiosandroid工具javascriptcap