Postman 保姆级使用

Postman 使用

当前使用postman版本:10.24.7

Postman可以创建多个工作空间 workspace,每个workspace都是个独立的空间,workspace内功能由 Environments、Collections组成使用。Environments默认有全局变量 Globals,这个下面变量Variable是在整个工作空间 workspace下生效的,除此之外还可以根据自己有多少环境相应的环境变量,Globals和自定义的环境下Variable可以相同,自定义环境切换到哪个就使用哪个环境里面的值,但环境里的变量是会覆盖Globals内的同名变量的,所以Globals内放置的都是全局公用的变量,多个环境内变化的变量才会放到自定义环境内

创建workspace

删除workspace

创建Collection与request

环境变量 Environments

使用环境变量传递数据

这里以token使用为例,正常每个请求都需要附带token才能进行请求,当掉用登录接口后,拿到token填入header中的Authorization进行下一步掉用,如果有特别多接口就非常不方便了,这里就可以将登录后拿到的accessTokenrefreshToken

放到环境变量中,其他地方直接使用变量填入响应的值,这里是使用Tests功能,它允许在发送请求后自动执行一些测试,并对服务器返回的响应进行验证

这里不止环境变量,Globals变量、集合变量也是可以用于Tests脚本设置的

js 复制代码
pm.globals.set("variableName", value); // 设置全局变量

pm.collectionVariables.set('variableName', value) // 设置集合变量

pm.variables.set("variableName", value); // 设置局部变量
// 局部变量或临时变量非常适合存储仅在当前请求或脚本执行期间需要的数据。不会被永久保存在 Postman中,也不会对其他请求或环境产生影响

至于获取token这里,不止使用Tests来设置,使用Pre-request Script也是可以的,不过这里需要使用js编写完整的登录请求获取结果再设置环境变量,postman里不能在Pre-request Script直接调用现有的登录接口

如果使用Pre-request Script,可以在集合上面来设置预运行脚本,这样集合下面的每个请求都会在发送请求前运行集合上的Pre-request Script脚步

js 复制代码
const d = new Date();
const t = d.getTime();
const lastRefreshTokenTime = parseInt(pm.environment.get("lastRefreshTokenTime"));
// 时间超过一个小时就重新登录刷新token	
if (t-lastRefreshTokenTime < 3600000) {
    return
}

const url = pm.globals.replaceIn("{{transportProtocol}}://{{host}}:{{port}}/user/login")


const req = {
    url: url,
    method: 'POST',
    header: {
        'Content-Type': 'application/json'
    },
    body: {
        mode: 'raw',
        raw: JSON.stringify({
            username: pm.globals.get('account'),
            password: pm.globals.get('password')
        })
    }
};
pm.sendRequest(req, function (err, response) {
  // 这里状态码判断逻辑根据实际修改
    if (response.code === 201) {
        const data = response.json()
        pm.environment.set('TOKEN', data.data.accessToken)
        pm.environment.set('REFRESH_TOKEN', data.data.accessToken)
        return
    }
    console.log(`Error: ${JSON.stringify(response.json())}`)
});

Pre-request Script与Tests使用场景

Pre-request Script会在请求发送前先执行,所以可以在这里调用其他接口,将数据添加到请求参数、headers里面,还可以在请求前根据请求生成验签数据等操作

Tests是在请求完成后才执行的,这时可以通过pm.response拿到请求结果数据了,所以就可以将部分数据存储到变量中用于其他接口使用,也可以对请求结果做断言测试

js 复制代码
// 请求前设置header参数
pm.request.headers.add({key:'X-SIGNATURE',value:XSIGNATURE});

// 获取请求前headers、请求方式、params、body、url。这些数据都在 pm.request 里面可以获取到
// 注意有些值是以数组的类型存储的,不过postman应该对这些数组做了修改,像.length、.forEach等函数是不能使用的
const headers =  pm.request.header
const httpMethod = pm.request.method
// 注意body的数据格式 { mode: 'raw', raw: { pageIndex: 0, pageSize: 10, }, options: { raw: { language: 'json' } }, };
const body = pm.request.body
// pm.request.url 包含内了protocol、path、host、query等数据按需取用即可
const query = pm.request.url.query
const protocol = pm.request.url.protocol
const path = pm.request.url.path
const host = pm.request.url.host

// 获取响应状态码
const responseCode = pm.response.code;
// 获取响应头
const responseHeaders = pm.response.headers;
// 获取响应体
const responseBody = pm.response.text();
// 将响应体解析为 JSON 对象,response返回的数据是Buffer类型的,正常使用需要转换
const jsonResponse = pm.response.json();
// 获取响应中的 Cookie
const responseCookies = pm.response.cookies;

可使用的外部库

learning.postman.com/docs/writin...

postman可用的外部库官网有13个:ajv、atob、btoa、chai、cheerio、crypto-js、csv-parse/lib/sync、lodash、moment、postman-collection、tv4、uuid、xml2js

部分NodeJS模块也是可以使用的,具体有哪些可以看一下文档

参数传递事例

事例为角色列表接口获取数据,随机从取到的数据中取一个对象,将其中两个字段放到集合变量中,供角色详情接口查询使用

js 复制代码
// Tests 脚本

const response = pm.response.json()

var roleList = [];
// console.log(response);
if(response.success && response.data.data.length>0){
    roleList = response.data.data
    let max = response.data.data.length
    let randomNum = Math.floor(Math.random() * max)
    let role = roleList[randomNum];
    // console.log('role',role)
    pm.collectionVariables.set('applicationCode',role.applicationCode)
    pm.collectionVariables.set('roleCode',role.roleCode)
}
相关推荐
蟾宫曲2 小时前
在 Vue3 项目中实现计时器组件的使用(Vite+Vue3+Node+npm+Element-plus,附测试代码)
前端·npm·vue3·vite·element-plus·计时器
秋雨凉人心2 小时前
简单发布一个npm包
前端·javascript·webpack·npm·node.js
liuxin334455662 小时前
学籍管理系统:实现教育管理现代化
java·开发语言·前端·数据库·安全
qq13267029402 小时前
运行Zr.Admin项目(前端)
前端·vue2·zradmin前端·zradmin vue·运行zradmin·vue2版本zradmin
魏时烟4 小时前
css文字折行以及双端对齐实现方式
前端·css
2401_882726485 小时前
低代码配置式组态软件-BY组态
前端·物联网·低代码·前端框架·编辑器·web
web130933203985 小时前
ctfshow-web入门-文件包含(web82-web86)条件竞争实现session会话文件包含
前端·github
胡西风_foxww5 小时前
【ES6复习笔记】迭代器(10)
前端·笔记·迭代器·es6·iterator
前端没钱5 小时前
探索 ES6 基础:开启 JavaScript 新篇章
前端·javascript·es6
m0_748255265 小时前
vue3导入excel并解析excel数据渲染到表格中,纯前端实现。
前端·excel