第三方网站测试工具:【Postman使用基础指南】

Postman 远不止一个 API 调试工具,它是一个完整的 API 开发环境,集成了设计、测试、模拟、文档化和监控等全流程功能。

工作区(Workspace):协作的核心单元,用于团队或个人组织 API 项目。分为个人、团队和公开工作区。

集合(Collection):API 请求的容器,是 Postman 中最核心的组织结构。一个集合对应一个 API 或一组相关功能。

请求(Request):单个 API 调用。包含 URL、方法、头、Body 等所有必要信息。

环境(Environment):一组键值对(变量)的集合,用于管理不同场景(开发、测试、生产)的配置,如 base_url, api_key。

界面导航

侧边栏:管理集合、API、环境、Mock 服务器和监控器。

请求构建器(Builder):

HTTP 方法:GET, POST, PUT, DELETE, PATCH 等。

请求 URL:可使用环境变量,如 {{base_url}}/api/v1/users。

Params:查询参数(Query String)。

Authorization:集中管理认证(API Key, OAuth 2.0, Bearer Token等)。

Headers:请求头。

Body:请求体,支持 form-data, x-www-form-urlencoded, raw(JSON, XML), binary 等。

响应查看器(Response):

Body:格式化(Pretty, Raw, Preview)的响应内容。

Cookies:服务器设置的 Cookies。

Headers:响应头。

Test Results:脚本的测试结果输出。

控制台(Console) (View > Show Postman Console):高级调试必备,显示所有请求和响应的原始数据,以及 console.log() 输出。

动态变量与脚本

Postman 的强大之处在于其沙箱(基于 Node.js)支持的预请求脚本(Pre-request Script)和测试脚本(Tests)。

动态变量:在脚本中生成动态值。

javascript 复制代码
// 在 Pre-request Script 中设置变量
pm.variables.set("timestamp", new Date().getTime());
pm.variables.set("random_email", "test" + Math.random() + "@example.com");

然后在 URL 或 Body 中使用 {{timestamp}} 和 {{random_email}}。

Tests 脚本:验证 API 行为,实现自动化测试。

javascript 复制代码
// 验证状态码
pm.test("Status code is 200", function () {
    pm.response.to.have.status(200);
});

// 验证响应体包含某个字符串
pm.test("Response contains user id", function () {
    pm.expect(pm.response.text()).to.include("user_id");
});

// 验证 JSON 响应结构
pm.test("Response JSON schema is valid", function () {
    const schema = {
        type: 'object',
        properties: {
            id: { type: 'number' },
            name: { type: 'string' }
        },
        required: ['id', 'name']
    };
    pm.response.to.have.jsonSchema(schema);
});

// 将响应中的 Token 设置为环境变量,用于后续请求
pm.test("Save authentication token", function () {
    const jsonData = pm.response.json();
    pm.environment.set("auth_token", jsonData.access_token);
});

Postman 在于它将 API 开发中的离散环节(请求、测试、文档、模拟、监控)整合到一个统一的平台,并通过变量、脚本和集合实现了高度的自动化和可维护性。

相关推荐
CryptoRzz2 分钟前
欧美(美股、加拿大股票、墨西哥股票)股票数据接口文档
java·服务器·开发语言·数据库·区块链
Never_Satisfied25 分钟前
在JavaScript / HTML中,div容器在内容过多时不显示超出的部分
开发语言·javascript·html
天才测试猿1 小时前
WebUI自动化测试:POM设计模式全解析
自动化测试·软件测试·python·selenium·测试工具·设计模式·测试用例
艾莉丝努力练剑1 小时前
【C++STL :stack && queue (一) 】STL:stack与queue全解析|深入使用(附高频算法题详解)
linux·开发语言·数据结构·c++·算法
胡萝卜3.01 小时前
深入理解string底层:手写高效字符串类
开发语言·c++·学习·学习笔记·string类·string模拟实现
西柚小萌新1 小时前
【Python从入门到精通】--Pycharm增加内存
开发语言·python·pycharm
不爱编程的小九九2 小时前
小九源码-springboot082-java旅游攻略平台
java·开发语言·旅游
只是懒得想了2 小时前
用C++实现一个高效可扩展的行为树(Behavior Tree)框架
java·开发语言·c++·design-patterns
yan8626592462 小时前
于 C++ 的虚函数多态 和 模板方法模式 的结合
java·开发语言·算法
Small___ming2 小时前
【Python基础】Python路径操作全解析:os.path、glob与pathlib从入门到精通
开发语言·python