Node.js模擬發(fā)起http請(qǐng)求從異步轉(zhuǎn)同步的5種用法
使用 Node.js 模擬發(fā)起 http 請(qǐng)求很常用的,但是由于 Node 模塊(原生和第三方庫(kù))提供里面的方法都是異步,對(duì)于很多場(chǎng)景下應(yīng)用很麻煩,不如同步來(lái)的方便。下面總結(jié)了幾個(gè)常見(jiàn)的庫(kù) API 從異步轉(zhuǎn)同步的幾種方法。模塊有: request , request-promise , request-promise-native , request-promise-any
PS: Node的版本>=8.0.0 為了使用 Async / Await PS: 這里加入 auth 字段是為了需要用戶(hù)名和密碼登錄的應(yīng)用的請(qǐng)求 ,比如 rabbitmq ,不需要登錄的頁(yè)面可以去掉這個(gè)參數(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 字段是為了需要用戶(hù)名和密碼登錄的應(yīng)用的請(qǐng)求 ,比如rabbitmq ,不需要登錄的頁(yè)面可以去掉這個(gè)參數(shù)。
//1: 原生寫(xiě)法 無(wú)auth 參數(shù)
getPromise(url).then((value)=>{
console.log("value" , value );
}).catch((err)=>{
console.log("err" , err );
});
//2: 原生寫(xiě)法 有auth 參數(shù)
getPromise(url , {'auth' : {
'user' : 'xx',
'pass' : 'xx',
'sendImmediately' : 'false',
}}).then((value)=>{
console.log("value" , value );
}).catch((err)=>{
console.log("err" , err );
});
// 第二種寫(xiě)法 async/await
// 個(gè)人最建議使用這種 , 只使用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()` 寫(xiě)法。
第二種
// 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, // 這個(gè)看你的參數(shù)而定
};
let rpnbody = await rpn(options);
console.log("rpnbody" , rpnbody );
}
useRequestPromiseNative();
使用模塊 request-promise-native , request-promise-native 是使用 native Promise 寫(xiě)的,查看源碼可以看到繼承自 Request 模塊 , 代碼示例如下:
// 不再寫(xiě) 原生示例 then()鏈的那種,參考第一個(gè)示例即可
//get 請(qǐng)求示例
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, // 這個(gè)看你的參數(shù)而定
};
let rpnbody = await rpn(options);
console.log("rpnbody" , rpnbody );
}
useRequestPromiseNative();
第三種
使用模塊 request-promise , request-promise 是基于 bluebird 寫(xiě)的, 查看源碼可以看到繼承自 Request 模塊 , 代碼示例如下:
// 不再寫(xiě)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 寫(xiě)的, 代碼示例如下:
// 不再寫(xiě)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請(qǐng)求從異步轉(zhuǎn)同步的5種用法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- Node.js中同步和異步編程的區(qū)別及使用方法
- Node.js基礎(chǔ)入門(mén)之回調(diào)函數(shù)及異步與同步詳解
- Nodejs讓異步變成同步的方法
- node.js中的forEach()是同步還是異步呢
- 我的Node.js學(xué)習(xí)之路(三)--node.js作用、回調(diào)、同步和異步代碼 以及事件循環(huán)
- 掌握Node.js中的Promise異步編程方式
- async/await與promise(nodejs中的異步操作問(wèn)題)
- NodeJS中利用Promise來(lái)封裝異步函數(shù)
- node異步方法的異步調(diào)用與同步調(diào)用實(shí)現(xiàn)方法示例
相關(guān)文章
node.js中module模塊的功能理解與用法實(shí)例分析
這篇文章主要介紹了node.js中module模塊的功能理解與用法,結(jié)合實(shí)例形式分析了node.js module模塊的基本功能、原理、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2020-02-02
node.js(expree.js?)模擬手機(jī)驗(yàn)證碼登錄功能
這篇文章主要介紹了node.js(expree.js?)模擬手機(jī)驗(yàn)證碼功能及登錄功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01
使用Nodejs編寫(xiě)一個(gè)腳本實(shí)現(xiàn)markdown轉(zhuǎn)pdf功能
Markdown?是一種輕量級(jí)的標(biāo)記語(yǔ)言,非常適合用來(lái)寫(xiě)作和記錄,將?Markdown?轉(zhuǎn)換為?PDF?可以讓文檔在格式和樣式上更加統(tǒng)一,也方便在不同設(shè)備和平臺(tái)上查看和打印,在接下來(lái)的內(nèi)容中我們將講解如何使用?NodeJs?編寫(xiě)一個(gè)?Markdown?轉(zhuǎn)?PDF?的腳本來(lái)實(shí)現(xiàn)我們這個(gè)想要的功能2024-05-05
Node.js實(shí)現(xiàn)簡(jiǎn)單管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Node.js實(shí)現(xiàn)簡(jiǎn)單管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
關(guān)于NodeJs和JAVA建立socket連接方式
這篇文章主要介紹了關(guān)于NodeJs和JAVA建立socket連接方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06
Sublime Text3 配置 NodeJs 環(huán)境的方法
大家都知道,Sublime Text 安裝插件一般從 Package Control 中直接安裝即可,當(dāng)我安裝 node js 插件時(shí)候,直接通過(guò)Package Control 安裝,雖然插件安裝成功了,但是找不到配置文件 Nodejs.sublime-build 來(lái)更改一些配置2020-05-05

