postman请求头加密_使用postman发送ase加密请求

刚知道postman可以在发送请求前执行js脚本,因为接口是加密的,之前每次测试都是先将加密代码注释掉,上线时再放开,所以就想是否能直接用postman发送带加密的请求。

加密请求需求

需要对一段json直接做加密,而非一个字段,如直接对 {"sign":{"action":"query","name":"张三"}} 中的 {"action":"query","name":"张三"} 这一段做加密。

加密算法:CBC,需要与你对应的解密算法一致,如果不一致,会在解密时出错

解决

1.post请求方式,在body中写好格式,sign不加密,sign里面的内容加密

20200728144057596154.png

2.在Pre_request Script 中添加脚本

20200728144058327627.jpg

注:上面这种方式,测试成功,你需要修改你对应的私钥等参数吧。

另外 遇到的一些问题,如果在脚本中添加 post发送请求的代码,会发送2次请求,一次是未加密的,一次是加密的,但是 我需要的都是加密请求,并且点击只需要发送一次就行了,所以我没有在脚本中写发送脚本的请求。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你想在Postman中对请求参数进行AES加密,你可以在"Pre-request Script"选项卡中使用CryptoJS库来实现。下面是一个示例代码,展示了如何在Postman中对请求参数进行AES加密: ```javascript // 引入CryptoJS库 const CryptoJS = require('crypto-js'); // 定义AES加密函数 function encryptAES(text, key, iv) { const encrypted = CryptoJS.AES.encrypt(text, key, { iv: iv }); return encrypted.toString(); } // 设置密钥和初始化向量 const key = CryptoJS.enc.Utf8.parse('1234567890123456'); // 设置密钥,必须是16位 const iv = CryptoJS.enc.Utf8.parse('1234567890123456'); // 设置初始化向量,必须是16位 // 加密请求参数 const plaintext = pm.request.body.raw; // 获取原始请求参数 const ciphertext = encryptAES(plaintext, key, iv); pm.request.body.raw = ciphertext; // 将加密后的参数设置为请求体 // 设置请求头 pm.request.headers.add({ key: 'Content-Type', value: 'application/json', }); pm.request.headers.add({ key: 'Encryption-Algorithm', value: 'AES', }); ``` 在上述代码中,我们首先引入CryptoJS库并定义了AES加密函数。然后,我们设置了密钥和初始化向量。接下来,我们获取原始请求参数并使用AES加密函数对其进行加密。最后,我们将加密后的参数设置为请求体,同时设置了相应的请求头。 请注意,上述代码假设请求参数是以JSON格式进行传输的,且请求头中有一个名为"Encryption-Algorithm"的自定义字段,用于指明采用的加密算法。根据你的实际需求,你可能需要对代码进行适当的调整。 注意:在实际应用中,为了安全起见,你可能需要将密钥和初始化向量存储在安全的地方,并在运行时从该地方读取,而不是在代码中明文写入。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值