背景説明インターフェースのテストに postman を使用するプロジェクトがあります。インターフェースに必要なパラメータは次のとおりです。
問題は、Postman がリクエストを開始するときに、パラメータに基づいて署名を動的に構築する方法です。 Postman スクリプト ライブラリでは、CryptoJS は HMACSHA1 や署名アルゴリズムを含むさまざまなアルゴリズムの暗号化をサポートしています。 難しいのは、URL 内のパス パラメータを取得することです。リクエストが開始されると、パス値が固定されます。自動テストを実行する必要がある場合、パス値を取得するにはどうすればよいでしょうか。 GETリクエストの作成ここでは、postman の基本的な使い方は紹介しません。まず、URL にさまざまな動的パラメータが設定された GET リクエストを作成します。 { {変数名}}: Postman が環境変数を参照するための構文。 { {$guid}}: GUID 値を取得するために使用される Postman 定義済み環境変数。 事前リクエストスクリプトで署名を作成する事前リクエスト スクリプトは、リクエストが送信される前に実行される JavaScript 実行環境です。js として使用するだけですが、一部の js ライブラリではサポートされていません。 次のステップは、署名を動的に取得することです 1. appid 環境変数に設定された固定値。 2. スタンプのタイムスタンプを取得します。 //Unix 時間を取得します。getUnixTime: function(){ return Math.round(new Date().getTime()/1000); } 3. URL 値は request.url を通じて取得でき、その後パスを解析できます。 // URL のパス部分を取得します getUrlRelativePath:function(url){ var arrUrl = url.split("//"); var start = arrUrl[1].indexOf("/"); var end=arrUrl[1].indexOf("?"); var relUrl = arrUrl[1].substring(start,end); //stop は省略され、start から end までのすべての文字がインターセプトされます console.log(relUrl); return relUrl; } 4. 署名文字列を作成し、秘密鍵を使用して暗号化します。 Postman が提供する暗号化アルゴリズム ライブラリは、すべてをサポートしていない可能性があり、バックエンドと署名を交換する必要がある場合もあります。 var ホスト = pm.environment.get("ホスト"); var テキスト = encodeURIComponent(プレーン); pm.sendRequest(host+"/FaceIn/ToHmacsha1?plain="+text+"&secret="+sercret, function (err, response) { var json=response.json(); //署名には + などの特殊文字が含まれており、URL エンコードする必要があります pm.environment.set("sign",encodeURIComponent(json.result)); }); 署名文字列は URL エンコードされることが望ましいです。 レガシー問題: バックエンドから署名を交換するときに、最初に文字列 responsejson() が返されますが、解析できません。 5. evalを使用して、定義された変数postmanUtilをグローバル変数に挿入し、呼び出します。 環境.postmanUtil を評価します。postmanUtil.setLsdzSign(); 結果は以下のようになります。 コードは次のとおりです。 var postmanUtil={ // Unix 時間を取得します getUnixTime:function(){ return Math.round(new Date().getTime()/1000); }, // URL のパス部分を取得します getUrlRelativePath:function(url){ var arrUrl = url.split("//"); var start = arrUrl[1].indexOf("/"); var end=arrUrl[1].indexOf("?"); var relUrl = arrUrl[1].substring(start,end); //stopは省略され、startからendまでのすべての文字がインターセプトされます console.log(relUrl); return relUrl; }, //署名 setLsdzSign:function(){ var appid=pm.environment.get("appid"); var sercret=pm.environment.get("appsercret"); //タイムスタンプ var time=postmanUtil.getUnixTime(); pm.environment.set("stamp", time); //アドレスは現在のアドレスのパス部分を取得しますvar path= postmanUtil.getUrlRelativePath(request.url); console.log(path); var url=path; var plain=appid+"$"+url.toLowerCase()+"$"+time; var hmac = CryptoJS.HmacSHA1(plain, sercret).toString(CryptoJS.enc.Base64); //署名を取得します。CryptoJS.HmacSHA1 は署名アルゴリズムを満たすことができないため、バックグラウンドからのみ取得できますvar host=pm.environment.get("host"); var text=encodeURIComponent(plain); pm.sendRequest(host+"/FaceIn/ToHmacsha1?plain="+text+"&secret="+sercret, function (err, response) { var json=response.json(); //署名には + などの特殊文字が含まれており、URL エンコードする必要があります pm.environment.set("sign",encodeURIComponent(json.result)); }); } }環境.postmanUtilを評価します。 postmanUtil.setLsdzSign(); スクリプトは環境変数に書き込まれます上記のコードをPre-request Scriptに記述します。インターフェースが1つであればそのままでも大丈夫です。インターフェースが複数ある場合でも、1つコピーするだけです。 スクリプトを変更する必要がある場合、問題が発生します。変更するには、各リクエストの事前リクエスト スクリプト ウィンドウに移動する必要があります。この問題を解決するにはどうすればよいでしょうか? これは、次のように ENVIRONMENT で postmanUtil を定義することで解決できます。 実際には、postmanUtil を環境変数に設定するだけです。他の変更はありません。環境変数の値を維持するだけで、1 つずつ変更する必要はありません。 事前リクエスト スクリプト コードを見ると、はるかに単純です。 Postmanコンソールの使い方環境変数が正常に取得されたかどうかわからない場合や、変数の値を表示したい場合、Postman には非常に便利なコンソール ビューも用意されています。[表示] メニューの [Postman コンソールを表示] を選択すると、次のコンソールが開きます。 図はconsole.log(sercret)とsendRequest()の結果を示しています。 コレクションランナー自動APIテストインターフェースのテストケースを作成する HTMLを返す結果については、テスト本体に特定の値が含まれていれば合格です。 返される Json 結果については、コードが 0 である限り渡されます。 ウィンドウの右側によく使われるスクリプトのショートカット操作があります。選択することで生成できます。とても便利です。 自動インターフェーステストを選択して実行するホームページの左上にあるランナーをクリックして入り、以前に構築したインターフェースを選択し、環境を選択して、xxxインターフェースの実行をクリックしてスクリプトテストを実行します。 テスト結果結果 2 インターフェースがスケジュールされた結果を正常に返していることがわかります。 Postman自動インターフェーステストの実践に関するこの記事はこれで終わりです。Postman自動インターフェーステストに関するより関連性の高いコンテンツについては、123WORDPRESS.COMの過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも123WORDPRESS.COMをよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: MySQL information_schema データベースの詳細な説明
>>: HTML でフォントの色を設定する方法と、PS を使用して HTML で正確なフォントの色を取得する方法
目次ReactRouterV6 の変更1. <Switch> が <Routes&...
5月の最も重要なインタラクティブデザイン記事!今年、Baiduのデザイナーは体験の観点から出発し、大...
今日はサーバーにログインして、データベース内のいくつかのものを変更する準備をしました。しかし、パスワ...
<br />条件付きコメントはIEシリーズ製品上でXHTMLコード処理を分離して行うこと...
MySQLのスイッチングデータ保存ディレクトリの実装方法今日、仕事中に、mysql が保存されている...
ここでは、v3 のインストールと使用にのみ焦点を当てます。v2 について学びたい場合は、公式 Web...
メタを使用して、ページの時間指定更新またはジャンプを実装します。 XML/HTML コードコンテンツ...
1. 動的クエリルール動的クエリルールは、おおよそ次の図のようになります。ユーザのカスタマイズに応じ...
導入HTML は、Web ドキュメントのコンテンツのコンテキスト構造と意味を提供します。HTML 自...
序文インターネット上にはデータベースの最適化に関する情報や方法が数多くありますが、その多くは品質にば...
前提条件Windows Server でコンテナーを実行するには、Windows Server (半...
W3C は最近、「 XHTML Basic1.1 」と「 Mobile Web Best Prac...
コードをコピーコードは次のとおりです。 <!--[IEの場合]><script t...
この記事はMySQL 8.0.12のインストールと設定に関する詳細なチュートリアルを記録しています。...
apk add ansible を使用して、alpine イメージに ansible サービスを追加...