nginx+postman,一种mock后端接口的异常场景测试方案

简介: ### 背景说明 有时在调测前端,或者想要测试验证前端对于后端异常的兼容性时,如果直接让后端模拟异常返回可能比较麻烦,此时,一种mock后端返回的方案将有助于快速调测。 网上也有不少相关的方案,比如通过Charles断点也可以修改后端接口的响应报文,但是如果前端设置了超时时长,那么有可能还没来得及修改响应报文,前端就已经因超时而失败了。当然,网上也有一些其他的类似Chrome插件的方式,我

背景说明

有时在调测前端,或者想要测试验证前端对于后端异常的兼容性时,如果直接让后端模拟异常返回可能比较麻烦,此时,一种mock后端返回的方案将有助于快速调测。

网上也有不少相关的方案,比如通过Charles断点也可以修改后端接口的响应报文,但是如果前端设置了超时时长,那么有可能还没来得及修改响应报文,前端就已经因超时而失败了。当然,网上也有一些其他的类似Chrome插件的方式,我目前还没有试用过,如果其他同学有好的分享,也欢迎留言。

本次记录的Nginx+postman的方案,虽然配置有些复杂,但是一旦配置完成,使用起来还是非常方便的。该方案的示意图如下。

image.png
接下来详细介绍配置过程。

postman mock服务端接口

postman mock服务端接口的方式比较多,也可以参考前面的文章:
postman mock接口返回,这里只简要记录常见的一种,操作过程如下所示:
mock-creation-app-cnx.gif

  • 第一步:在postman主控制面板点击New按钮,然后选择“Mock Server”
  • 第二步:设置mock接口的方法、访问路径、返回码和响应报文,然后点击Next
  • 第三步:设置Mock Server名称,[可选]设置环境,然后点击“Create Mock Server”
  • 第四步:点击“Copy Mock URL”复制出mock url(这是访问mock接口url前缀,也可以在collections详情中查看)
  • 第五步:然后就可以拼接mock url和第二步设置的访问路径来发送请求检查mock结果了

设置了mock server之后,可能最常用的操作就是修改mock接口的返回报文,可以这样操作:

  • 第一步:在mock server下选择想要修改返回报文的request
  • 第二步:选择Examples中的default(或者新建一个Example也行)
  • 第三步:修改Example中的响应报文并Save Example

之后再访问mock接口,看到的就是新的响应报文了
image.png

image.png

本地安装和配置Nginx

安装Nginx

安装Nginx比较简单,这里只记录Mac下的安装:

brew install nginx

生成自签证书

如果后端接口是http请求,那么这一步可以省略;
如果是https请求,那么就需要生成和配置证书

  • 第一步:进入Nginx目录,并新建一个目录存放证书相关信息
cd /usr/local/etc/nginx
mkdir ssl
cd ssl
  • 第二步:创建服务器私钥
openssl genrsa -out server.key 1024
  • 第三步:生成证书申请
openssl req -new -key server.key -out server.csr

cp server.key server.key.org
openssl rsa -in server.key.org -out server.key
  • 第四步:生成签署文件
openssl x509 -req -in server.csr -out server.crt -signkey server.key -days 3650

配置Nginx

进入Nginx config目录,配置nginx.conf

cd /usr/local/etc/nginx
vim nginx.conf
  • http接口可以在server下面这样配置:
        listen       8080;
        server_name  www.xx.com; # 后端服务的域名

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {               # 要转发的请求的路径
            root   html;
            index  index.html index.htm;
            proxy_pass http://315049fd-d7a2-4fff-ab56-48f4c73bbab0.mock.pstmn.io/test-mock;        # postman mock接口连接
        }
  • https接口可以在server下面这样配置:
        listen       443 ssl;
        server_name  www.xx.com; # 后端服务的域名

        ssl_certificate      /usr/local/etc/nginx/ssl/server.crt;
        ssl_certificate_key  /usr/local/etc/nginx/ssl/server.key;

        ssl_session_cache    shared:SSL:1m;
        ssl_session_timeout  5m;

        ssl_ciphers  HIGH:!aNULL:!MD5;
        ssl_prefer_server_ciphers  on;

        location /yyy {
            root   html;
            index  index.html index.htm;
            proxy_pass http://315049fd-d7a2-4fff-ab56-48f4c73bbab0.mock.pstmn.io/test-mock;        # postman mock接口连
        }

配置之后保存

启动Nginx

进入Nginx bin目录,启动Nginx。(Mac上安装之后可以直接在命令行输入nginx启动)

nginx

本地配置host

编辑hosts文件,新增一行配置,从而将本地到服务端接口的请求转发到nginx上,然后再由nginx转发请求到postman mock server。

vim /etc/hosts

新增一行并保存

# www.xx.com为服务端域名
127.0.0.1 www.xx.com

调试访问

在postman中调测

在postman中新建一个request,然后输入后端接口地址,模拟请求发送。此时可能会遇到下面的报错:“Error: self signed certificate”。

这时,可以在postman主控制面板,点击Postman > Preference打开postman设置界面,将General tab下面的“SSL certificate verification”设置为“OFF”

然后重新发送请求,检查是否为postman mock server的返回。
image.png

在浏览器中调测

浏览器直接访问前端时,可能会遇到上面一样的问题。后端接口报“net: ERR_CERT_INVALID”。

这时,可以直接在前端页面上输入“thisisunsafe”
image.png

或者浏览器新打开一个tab,访问服务端接口地址,然后会展示如下提示“您的连接不是私密连接”,然后同样的在该页面输入“thisisunsafe”
image.png
该问题的其他解决办法可以参考这位同学的总结:
https://segmentfault.com/a/1190000021843971

相关文章
|
5月前
|
人工智能 数据可视化 测试技术
Postman 性能测试教程:快速上手 API 压测
本文介绍API上线后因高频调用导致服务器告警,通过Postman与Apifox进行压力测试排查性能瓶颈。对比两款工具在批量请求、断言验证、可视化报告等方面的优劣,探讨API性能优化策略及行业未来发展方向。
Postman 性能测试教程:快速上手 API 压测
|
7月前
|
JSON JavaScript 测试技术
用Postman玩转电商API:一键测试+自动化请求教程
Postman 是电商 API 测试的高效工具,涵盖基础配置、自动化测试、环境管理与请求自动化,助你快速提升开发效率。
|
5月前
|
存储 前端开发 安全
实现“永久登录”:针对蜻蜓Q系统的用户体验优化方案(前端uni-app+后端Laravel详解)-优雅草卓伊凡
实现“永久登录”:针对蜻蜓Q系统的用户体验优化方案(前端uni-app+后端Laravel详解)-优雅草卓伊凡
272 5
|
5月前
|
人工智能 数据可视化 测试技术
AI 时代 API 自动化测试实战:Postman 断言的核心技巧与实战应用
AI 时代 API 自动化测试实战:Postman 断言的核心技巧与实战应用
720 11
|
数据可视化 前端开发 测试技术
接口测试新选择:Postman替代方案全解析
在软件开发中,接口测试工具至关重要。Postman长期占据主导地位,但随着国产工具的崛起,越来越多开发者转向更适合中国市场的替代方案——Apifox。它不仅支持中英文切换、完全免费不限人数,还具备强大的可视化操作、自动生成文档和API调试功能,极大简化了开发流程。
|
Dubbo 应用服务中间件 API
使用 Apifox、Postman 测试 Dubbo 服务,Apache Dubbo OpenAPI 即将发布
Apache Dubbo 3.3.3(即将发布)实现了与 OpenAPI 的深度集成,通过与 OpenAPI 的深度集成,用户能够体验到从文档生成到接口调试、测试和优化的全流程自动化支持。不论是减少手动工作量、提升开发效率,还是支持多语言和多环境,Dubbo 3.3.3 都展现了其对开发者体验的极大关注。结合强大的 Mock 数据生成和自动化测试能力,这一版本为开发者提供了极具竞争力的服务治理解决方案。如果你正在寻找高效、易用的微服务框架,Dubbo 3.3.3 将是你不容错过的选择。
1274 253
|
10月前
|
数据可视化 测试技术 API
JMeter、Apipost 与 Postman 的 API 测试对比:为什么 APIPost 是更聪明的选择
API测试如同筹备一场晚宴,选对工具至关重要。JMeter功能强大但上手难,适合专业用户;Postman简单易用,但在复杂场景和团队协作中表现有限;而Apipost则是一款智能高效的“厨房神器”。它性能测试轻松、结果清晰、学习门槛低,并且能一键集成CI/CD流程。对于追求效率与便捷的团队而言,Apipost无疑是更优选择,让API测试如同五星大厨烹饪般丝滑流畅。
|
10月前
|
存储 前端开发 数据可视化
Postman vs. Apifox 用于 API 测试全面对比
寻找一款可靠的 API 测试工具?这份对比分析将深入探讨 Postman 和 Apifox 的功能和特性。了解哪款工具最适合您的 API 测试需求。
|
10月前
|
XML JSON 测试技术
如何使用 Postman 发送和测试 WebSocket
WebSocket 促进客户端和服务器之间通过单个持久连接进行实时、双向通信。 需要使用 Postman 建立 WebSocket 连接吗? 请查看我们简洁的循序渐进指南!
|
10月前
|
监控 安全 测试技术
选择Postman免费版还是付费版,进行 API 测试呢?
深入了解 Postman 免费版和付费版的细节,看看哪一个更适合您的 API 需求。