当前位置:   article > 正文

postman请求响应加解密

postman请求响应加解密

部分接口,需要请求加密后,在发动到后端。同时后端返回的响应内容,也是经过了加密。此时,我们先和开发获取到对应的【密钥】,然后在postman的预执行、后执行加入js脚本对明文请求进行加密,然后在发送请求;响应回来后,后执行会解密响应内容。

如aes加密请求。

预执行操作:

  1. //预执行
  2. const crypto = require('crypto-js')
  3. let timeNow = Date.now();
  4. var key = crypto.enc.Utf8.parse(pm.environment.get('key')); // 16字节的密钥
  5. var iv = crypto.enc.Utf8.parse(pm.environment.get('iv')); // 16字节的初始化向量
  6. if (pm.request.body) {
  7. // 要加密的数据
  8. objJson = JSON.parse(pm.request.body.raw)
  9. objJson.Data.incidentTime = timeNow
  10. objJson.TimeStamp = timeNow
  11. console.log('加密前的请求数据:', objJson);
  12. var data = JSON.stringify(objJson.Data);
  13. // 使用 AES 加密(使用 ECB 模式)
  14. var encryptedData = crypto.AES.encrypt(data, key, { iv: iv, mode: crypto.mode.CBC, padding: crypto.pad.Pkcs7 });
  15. objJson.Data = encryptedData.toString();
  16. pm.request.body.raw = objJson;
  17. // 输出加密后的结果
  18. console.log('加密后的数据:', pm.request);
  19. }

预执行,控制台输出 

后执行操作:

  1. const crypto = require('crypto-js')
  2. if (responseBody) {
  3. var result = JSON.parse(responseBody);//把返回的字符串格式数据转换为对象的形式,并保存到result变量中
  4. var key = crypto.enc.Utf8.parse(pm.environment.get("key"));
  5. var iv = crypto.enc.Utf8.parse(pm.environment.get("iv"));
  6. if (result.Data) {
  7. var decryptedData = crypto.AES.decrypt(result.Data, key, { iv: iv, mode: crypto.mode.CBC, padding: crypto.pad.Pkcs7 });
  8. var decryptedText = decryptedData.toString(crypto.enc.Utf8)
  9. result.Data = decryptedText;
  10. pm.response.raw = JSON.stringify(result);
  11. pm.response.raw.set = result;
  12. console.log('响应解密', pm.response.raw);
  13. }
  14. }

响应解密 

本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/909334
推荐阅读
相关标签
  

闽ICP备14008679号