news 2026/6/23 6:30:38

Playwright 网络拦截

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Playwright 网络拦截

Playwright 网络拦截(Route & Request Interception)(2025 年最新版)

网络拦截是 Playwright 最强大的功能之一,允许你拦截、修改、mock 或中止浏览器发出的任何网络请求(XHR、fetch、API 调用、图片、CSS 等)。常用于:

  • Mock API 响应(加速测试、避免真实后端依赖)
  • 测试错误场景(404、500、超时)
  • 修改请求头/参数
  • 模拟网络延迟或离线
  • 捕获 API 数据进行断言

Playwright 使用page.route()route.handler()实现拦截,支持通配符匹配。

1.基本用法:拦截并 Mock 响应
// tests/mock-api.spec.tsimport{test,expect}from'@playwright/test';test('Mock API 返回固定数据',async({page})=>{// 拦截所有 /api/users 请求awaitpage.route('**/api/users',asyncroute=>{// Mock 一个成功的 JSON 响应awaitroute.fulfill({status:200,contentType:'application/json',headers:{'Access-Control-Allow-Origin':'*'},// 可选:处理 CORSbody:JSON.stringify([{id:1,name:'Mock 用户1'},{id:2,name:'Mock 用户2'},]),});});awaitpage.goto('https://your-app.com/users');// 页面会显示我们 mock 的数据awaitexpect(page.getByRole('heading')).toHaveText('用户列表');awaitexpect(page.getByText('Mock 用户1')).toBeVisible();});
2.常见拦截模式
场景代码示例说明
继续原请求(不修改)await route.continue();默认行为,常用于日志记录
修改请求(添加头/参数)```await
中止请求(模拟失败)await route.abort('failed');await route.abort();触发 network error
模拟错误响应await route.fulfill({<br> status: 500,<br> body: 'Server Error'<br>});返回 4xx/5xx
重定向await route.fulfill({ status: 301, headers: { location: '/new-url' } });模拟重定向
模拟网络延迟await page.route('**/*', async route => {<br> await new Promise(r => setTimeout(r, 2000)); // 延迟 2s<br> await route.continue();<br>});测试 loading 状态
拦截特定类型资源await page.route('**/*.{png,jpg,jpeg}', route => route.abort());阻塞图片加载(加速测试)
3.高级:根据请求动态决定
awaitpage.route('**/api/**',asyncroute=>{constmethod=route.request().method();if(method==='GET'&&route.request().url().includes('users/1')){awaitroute.fulfill({json:{id:1,name:'特殊用户',vip:true}});// shorthand for JSON}elseif(method==='POST'){// 记录请求体用于断言constpostData=route.request().postDataJSON();console.log('收到 POST 数据:',postData);awaitroute.fulfill({status:201,json:{success:true}});}else{awaitroute.continue();}});
4.捕获响应进行断言
// 等待特定响应并验证const[response]=awaitPromise.all([page.waitForResponse('**/api/login'),page.getByRole('button',{name:'登录'}).click(),]);expect(response.status()).toBe(200);constjson=awaitresponse.json();expect(json.token).toBeTruthy();
5.拦截 WebSocket(Playwright v1.30+ 支持)
awaitpage.route('wss://example.com/socket',route=>{// WebSocket 拦截目前有限制,通常用 route.continue() + page.on('websocket')route.continue();});page.on('websocket',ws=>{console.log(`WebSocket 打开:${ws.url()}`);ws.on('framesent',frame=>console.log('发送:',frame));});
6.Python 版示例(Mock API)
defhandle_route(route):if"api/users"inroute.request.url:route.fulfill(status=200,content_type="application/json",body='[{"id":1,"name":"Mock 用户"}]')else:route.continue_()page.route("**/api/**",handle_route)page.goto("https://your-app.com")
最佳实践总结
  • 匹配规则:使用**/通配符(如**/api/**)覆盖所有子路径。
  • 优先级:先定义具体路由,后定义通用路由(后定义的优先)。
  • 清理:测试结束无需手动 unroute,Playwright 会自动清理。
  • 生产测试:结合route.fulfill()mock 不稳定第三方 API。
  • 调试:用page.on('request')page.on('response')打印日志观察拦截效果。

网络拦截能让你完全掌控测试环境,避免外部依赖导致的 flaky 测试。下一步建议:实现一个完整的登录流程,使用网络拦截 mock 登录 API 并验证返回 token。

需要更复杂的场景(如文件下载拦截、GraphQL Mock、多环境切换),随时告诉我!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 19:37:49

ECharts 饼图(Pie Chart)教程

ECharts 饼图&#xff08;Pie Chart&#xff09;教程 ECharts 的饼图&#xff08;series.type ‘pie’&#xff09;主要用于展示数据在总体中的占比比例&#xff0c;支持实心饼图、圆环图&#xff08;南丁格尔图/玫瑰图&#xff09;、多层嵌套等变体。数据通过 data 数组中的…

作者头像 李华
网站建设 2026/6/23 11:47:49

Open-AutoGLM日志加密部署难题:90%团队忽略的2个致命风险点

第一章&#xff1a;Open-AutoGLM 日志数据加密存储在 Open-AutoGLM 系统中&#xff0c;日志数据的安全性至关重要。为防止敏感信息泄露&#xff0c;系统采用端到端加密机制对日志进行安全存储。所有日志在写入磁盘前均经过加密处理&#xff0c;确保即使存储介质被非法获取&…

作者头像 李华
网站建设 2026/6/23 19:53:25

精密机械工厂6个研发如何共享一台SolidWorks云工作站

在精密机械制造行业&#xff0c;产品研发效率与协同能力直接决定市场竞争力。当6名工程师需要共享SolidWorks云工作站时&#xff0c;可借助智能共享云桌面&#xff0c;通过以下综合方案实现共享一台SolidWorks云工作站的目标&#xff0c;该方案涵盖硬件配置、资源管理、软件部署…

作者头像 李华
网站建设 2026/6/23 19:53:52

Open-AutoGLM监控总失效?99%人忽略的3个配置陷阱

第一章&#xff1a;Open-AutoGLM异常访问监控配置在部署 Open-AutoGLM 服务时&#xff0c;保障系统安全与稳定性至关重要。异常访问监控是及时发现潜在攻击、滥用行为或系统故障的关键机制。通过合理配置日志采集、访问频率限制和行为分析规则&#xff0c;可有效识别并阻断异常…

作者头像 李华
网站建设 2026/6/22 19:59:33

LangFlow静态站点生成(SSG)可行性探讨

LangFlow静态站点生成&#xff08;SSG&#xff09;可行性探讨 在AI应用开发日益普及的今天&#xff0c;越来越多团队希望快速构建、展示并共享基于大语言模型的工作流。然而&#xff0c;传统的LangChain项目往往依赖复杂的代码结构和持续运行的服务端环境&#xff0c;使得非技术…

作者头像 李华
网站建设 2026/6/23 19:55:42

Linux 如何设置开机自启:全面指南!

在日常运维和开发中&#xff0c;我们经常希望某些程序或服务在系统启动时自动运行&#xff0c;比如 Web 服务、数据库、监控脚本、定时任务等。本文将详细介绍在 Linux 系统中设置开机自启的常见方法&#xff0c;适用于常见发行版如 CentOS、Ubuntu、Debian 等。 一、使用 syst…

作者头像 李华