ホームページ >ウェブフロントエンド >jsチュートリアル >Node.js が http リクエストをシミュレートする方法は何ですか? (方法の概要)
この記事でわかることは、Node.js が http リクエストの開始をシミュレートする方法は何なのかということです。 (方法の概要)は、必要な友人がそれを参考にできることを願っています。
Node.js を使用して http リクエストの開始をシミュレートするのは非常に一般的ですが、Node モジュール (ネイティブ ライブラリとサードパーティ ライブラリ) が提供するメソッドはすべて非同期であるため、非常に面倒です。多くのシナリオに適用するには、同期すると便利です。以下に、いくつかの共通ライブラリ API を非同期から同期に変換するためのいくつかの方法をまとめます。モジュールは次のとおりです: request、request-promise、request-promise-native、request-promise-any
PS: ノードのバージョン>=8.0.0 Async/Await を使用するには
PS: 認証を追加しますこのフィールドは、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 は、ネイティブ Promise を使用して記述されています。ソース コードを見ると、Request モジュールから継承されていることがわかります。コード例は次のとおりです。 #3 番目の
// 不再写 原生示例 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();
4 番目の
// 不再写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();
// 不再写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();
以上がNode.js が http リクエストをシミュレートする方法は何ですか? (方法の概要)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。