Node.js模擬發(fā)起http請求從異步轉(zhuǎn)同步的5種用法
使用 Node.js 模擬發(fā)起 http 請求很常用的,但是由于 Node 模塊(原生和第三方庫)提供里面的方法都是異步,對于很多場景下應(yīng)用很麻煩,不如同步來的方便。下面總結(jié)了幾個常見的庫 API 從異步轉(zhuǎn)同步的幾種方法。模塊有: request , request-promise , request-promise-native , request-promise-any
PS: Node的版本>=8.0.0 為了使用 Async / Await PS: 這里加入 auth 字段是為了需要用戶名和密碼登錄的應(yīng)用的請求 ,比如 rabbitmq ,不需要登錄的頁面可以去掉這個參數(shù)。
第一種
使用原生模塊 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 字段是為了需要用戶名和密碼登錄的應(yīng)用的請求 ,比如rabbitmq ,不需要登錄的頁面可以去掉這個參數(shù)。
//1: 原生寫法 無auth 參數(shù)
getPromise(url).then((value)=>{
console.log("value" , value );
}).catch((err)=>{
console.log("err" , err );
});
//2: 原生寫法 有auth 參數(shù)
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` 參數(shù)的用法參考[鏈接][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參數(shù)
}
json: true, // 這個看你的參數(shù)而定
};
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 里面的參數(shù)可以去看request的源碼 查看其index.d.ts 文件里面的 interface CoreOptions 里面有所有的參數(shù)。
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參數(shù)
}
json: true, // 這個看你的參數(shù)而定
};
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 轉(zhuǎn)成 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()
總結(jié)
以上所述是小編給大家介紹的Node.js模擬發(fā)起http請求從異步轉(zhuǎn)同步的5種用法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- Node.js中同步和異步編程的區(qū)別及使用方法
- Node.js基礎(chǔ)入門之回調(diào)函數(shù)及異步與同步詳解
- Nodejs讓異步變成同步的方法
- node.js中的forEach()是同步還是異步呢
- 我的Node.js學(xué)習(xí)之路(三)--node.js作用、回調(diào)、同步和異步代碼 以及事件循環(huán)
- 掌握Node.js中的Promise異步編程方式
- async/await與promise(nodejs中的異步操作問題)
- NodeJS中利用Promise來封裝異步函數(shù)
- node異步方法的異步調(diào)用與同步調(diào)用實現(xiàn)方法示例
相關(guān)文章
Node.js基礎(chǔ)入門之回調(diào)函數(shù)及異步與同步詳解
Node.js是一個基于Chrome?V8引擎的JavaScript運行時。類似于Java中的JRE,.Net中的CLR。本文將詳細為大家介紹Node.js中的回調(diào)函數(shù)及異步與同步,感興趣的可以了解一下2022-03-03
Node.js操作mysql數(shù)據(jù)庫增刪改查
這篇文章主要介紹使用Node.js操作mysql數(shù)據(jù)庫增刪改查的相關(guān)資料,需要的朋友可以參考下2016-03-03
node.js 中間件express-session使用詳解
這篇文章主要給大家介紹了node.js中間件express-session使用的相關(guān)資料,文中介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-05-05

