当前位置:首页 > 后端 > 正文内容

Postman高级技巧:Pre-Request Script 和 Tests

1年前 (2024-08-07)后端

最近使用postman调试接口时,遇到个问题,接口需要签名。每次调试的时候都需要服务端来查看签名然后再提交到postman里面进行请求,非常麻烦!

查看官方文档,发现了Pre-Request Script这个工具,就研究了下,下面是具体实现的步骤。

话不多说,上代码!代码逻辑是获取参数后排序后和秘钥拼接,然后md5转大写,由于js不熟,以下代码有点繁琐!


  • //pm.collectionVariables.set("time", new Date())
  • var paramKey = [];
  • var paramQuery = '';
  • var data = {};
  • // 获取请求部分的参数
  • if ('POST' == pm.request.method) {
  • data = pm.request.body.urlencoded.toObject();
  • else {
  • data = pm.request.url.query.toObject();
  • }
  • // 把参数放入数组进行key排序
  • for (item in data) {
  • if ('sign' == item) {
  • continue;
  • }
  • paramKey.push(item);
  • }
  • paramKey.sort();
  • for (const key of paramKey) {
  • if (data.hasOwnProperty(key)) {
  • paramQuery += key + '=' + data[key] + '&'
  • }
  • }
  • paramQuery += 'key=' + pm.environment.get("key_" + data['partner_id']);
  • var sign = CryptoJS.MD5(paramQuery).toString().toUpperCase();
  • pm.collectionVariables.set("sign", sign);
  • //pm.environment.set("sign", sign);

返回参数需要校验,直接上代码

  • // base64解码返回参数
  • var data = CryptoJS.enc.Base64.parse(responseBody);
  • // 解析成一个json对象
  • var jsonData = JSON.parse(CryptoJS.enc.Utf8.stringify(data));
  • // 判断返回值是否==200
  • tests["Check response code value"] = jsonData.code === '200';

附postman常用方法

  • //  常用获取参数
  • pm.environment.get("variable_key");
  • pm.globals.get("variable_key");
  • pm.variables.get("variable_key");
  • pm.environment.set("variable_key""variable_value");
  • pm.environment.unset("variable_key");
  • pm.environment.unset("variable_key");
  • pm.globals.unset("variable_key");
  • pm.sendRequest("https://postman-echo.com/get"function (err, response) {
  • console.log(response.json());
  • });
  • # 断言
  • # 校验接口响应的状态码,常见的有 200404500当然也包括前面鉴权学到的 401 等等
  • pm.test("Status code is 200"function () {
  • pm.response.to.have.status(200);
  • });
  • # 检查响应信息中是否包含某些指定的字符串;
  • pm.test("Body matches string"function () {
  • pm.expect(pm.response.text()).to.include("string_you_want_to_search");
  • });
  • # 检查从JSON响应中获取到某个字段,判断其是否与预期字段一致;
  • pm.test("Your test name"function () {
  • var jsonData = pm.response.json();
  • pm.expect(jsonData.value).to.eql(100);
  • });
  • # 检查实际获取的响应体(即 Body 信息)与预期结果的响应体是否一致;
  • pm.test("Body is correct"function () {
  • pm.response.to.have.body("response_body_string");
  • });
  • # 检查响应中的头域信息(Headers)是否与预期一致;
  • pm.test("Content-Type is present"function () {
  • pm.response.to.have.header("Content-Type");
  • });
  • # 判断实际响应时间是否与低于预期时间
  • pm.test("Response time is less than 200ms"function () {
  • pm.expect(pm.response.responseTime).to.be.below(200);
  • });
  • # 检查响应码是否与预期集合中的某个值一致
  • pm.test("Successful POST request"function () {
  • pm.expect(pm.response.code).to.be.oneOf([201,202]);
  • });
  • # 检查响应信息中是否包含某个预期值
  • pm.test("Status code name has string"function () {
  • pm.response.to.have.status("Created");
  • });

手机扫描二维码访问

阅读剩余的72%

扫描二维码推送至手机访问。

版权声明:本文由Magic发布,如需转载请注明出处。

本文链接:http://www.maguochang.com/?id=6

返回列表

没有更早的文章了...

下一篇:Bad credentials异常

“Postman高级技巧:Pre-Request Script 和 Tests” 的相关文章

Bad credentials异常

在spring-security中出现Bad credentials异常,可能是如下情况:一.username和password错误二.访问权限不够三.密码加密问题,对于密码加密问题可能是如下情况:1.密码无加密,这时应该在密码前加上 {noop},具体原因请翻阅官方apiUser use...

正则表达式取反

取反正则:^((?!要取反的正则表达式).)*$示例:import java.util.regex.Matcher; import java.util.regex.Pattern;   public class Main { &nb...