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

使用Node.js模擬發起http請求很經常使用的,可是因爲Node模塊(原生和第三方庫)提供裏面的方法都是異步,對於不少場景下應用很麻煩,不如同步來的方便。下面總結了幾個常見的庫API從異步轉同步的幾種方法。模塊有:request, request-promise , request-promise-native , request-promise-any json

PS:Node的版本>=8.0.0 爲了使用 Async / Await
PS: 這裏加入auth 字段是爲了須要用戶名和密碼登陸的應用的請求 ,好比rabbitmq ,不須要登陸的頁面能夠去掉這個參數。promise

第一種

使用原生模塊 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 模塊 , 代碼示例以下:async

// 再也不寫 原生示例  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

// 再也不寫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 寫的, 代碼示例以下:ui

// 再也不寫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 , 代碼示例以下:url

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種了,你們根據本身須要來選擇。code

相關文章
相關標籤/搜索