news 2026/3/27 17:38:11

使用 Puppeteer 设置 Cookies 并实现自动化分页操作:前端实战教程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用 Puppeteer 设置 Cookies 并实现自动化分页操作:前端实战教程

使用 Puppeteer 设置 Cookies 并自动化分页操作

在现代的 Web 自动化中,使用 Puppeteer 进行浏览器自动化是一个非常方便的选择。本篇文章将介绍如何使用 Puppeteer 设置 Cookies、模拟用户行为、获取网页内容,并且遍历分页获取所有数据。

一、项目初始化

首先,我们需要安装 Puppeteer。你可以通过 npm 来安装:

npminstallpuppeteer

然后创建一个 JavaScript 文件,例如puppeteer.js,以若依测试。并添加以下代码:

二、代码实现

constpuppeteer=require('puppeteer');constfs=require('fs');// 导入文件系统模块// 设置延时的工具函数functionwaitForTimeout(time){returnnewPromise((resolve,reject)=>setTimeout(resolve,time));}(async()=>{// 启动 Puppeteer 浏览器实例constbrowser=awaitpuppeteer.launch({headless:false// 设置为 false 以便查看操作});try{constpage=awaitbrowser.newPage();awaitpage.setViewport({width:1920,height:800});// 导航到需要设置 cookie 的页面awaitpage.goto('http://localhost:8093/admin');// 定义多个 cookie 对象并存储在数组中constcookies=[{"name":"Admin-Token","value":"eyJhbGciOiJIUzUxMiJ9.eyJsb2dpbl91c2VyX2tleSI6IjYzYWNmZTVmLWUyNGItNDYwNi05ZjdhLTBkYmU5ZDBhZWJmZCJ9.RqZDMMiRTGUwVSLal9dx2mDyHwkY_vk4Vs2bMSegph7P0eTnKDknN5DOP3wRu18e2NVk5OdVSfJcLmC0N1HHHQ"}// 可以继续添加更多 cookie 对象];// 使用 page.setCookie 方法设置多个 cookieawaitpage.setCookie(...cookies);// 打印当前页面的 cookiesconstcookies1=awaitpage.cookies();console.log('当前页面的 cookies:',cookies1);// 导航到目标页面awaitpage.goto('http://localhost:8093/category');// 使用 XPath 选择带有特定文本的按钮constxpathSelectorC='//span[text()="50条/页"]';awaitpage.waitForXPath(xpathSelectorC);// 获取符合条件的元素并模拟点击操作const[element]=awaitpage.$x(xpathSelectorC);if(element){awaitelement.evaluate(element=>element.click());console.log('已选择 "50条/页"');}else{console.log('未找到 "50条/页"');}// 等待分页元素加载完成awaitpage.waitForSelector('ul.el-pager');// 获取分页的所有 <li> 元素constliElements=awaitpage.$$('ul.el-pager li');constlastLiElement=liElements[liElements.length-1];letlastLiText=0;if(lastLiElement){lastLiText=awaitpage.evaluate(li=>li.textContent,lastLiElement);console.log('最后一个 <li> 元素的内容:',lastLiText);}else{console.log('未找到 <li> 元素');}// 定义表格和分页按钮选择器consttableSelector='table';constnextButtonSelector='button.btn-next';// 等待下一页按钮可见awaitpage.waitForSelector(nextButtonSelector,{visible:true,timeout:5000});consttotalPages=parseInt(lastLiText);// 获取总页数letcurrentPage=1;letallTableHTML='';// 用于保存所有表格的 HTML 内容// 遍历所有分页while(currentPage<=totalPages){constbuttonElement=awaitpage.$(nextButtonSelector);consttableElements=awaitpage.$$(tableSelector);if(buttonElement){// 点击“下一页”按钮awaitbuttonElement.click();awaitwaitForTimeout(3000);// 等待加载// 获取当前页面的表格内容并保存for(consttableElementoftableElements){consttableHTML=awaittableElement.evaluate(element=>element.outerHTML);allTableHTML+=tableHTML;}currentPage++;// 增加当前页数}else{console.log('未找到按钮');break;// 如果按钮不存在,退出循环}}console.log('已浏览到第 '+totalPages+' 页');// 你可以将 allTableHTML 保存为文件或进一步处理fs.writeFileSync('allTables.html',allTableHTML);// 完成后关闭浏览器awaitbrowser.close();}catch(e){console.log("发生错误:"+e);}})();

三、代码说明

  1. 启动浏览器实例
    使用puppeteer.launch()启动一个浏览器实例。headless: false表示我们希望看到浏览器的操作界面,便于调试。

  2. 设置 Cookies
    使用page.setCookie(...cookies)设置多个 Cookie。我们通过传递一个包含多个 cookie 对象的数组来设置 Cookies。

  3. 等待和选择元素
    使用page.waitForXPath()page.waitForSelector()来确保元素加载完成后进行交互。特别是通过 XPath 选择“50条/页”按钮,并模拟点击它。

  4. 分页操作
    使用page.$(nextButtonSelector)page.$$(tableSelector)获取“下一页”按钮和表格元素,进行分页处理。每一页的数据都通过tableElement.evaluate()获取 HTML 内容,并累积到allTableHTML中。

  5. 文件保存
    最后,所有页面表格的 HTML 内容保存在一个文件allTables.html中,使用 Node.js 的fs模块来实现文件保存。

四、总结

通过以上代码,你可以模拟在 Web 页面上设置 Cookies、模拟用户行为并自动化分页操作。你可以根据具体需求对该代码进行修改,以实现更复杂的自动化任务。

Puppeteer 是一个强大的浏览器自动化工具,适用于多种 Web 数据抓取和自动化任务。希望本文的示例代码能帮助你入门 Puppeteer,并加速你在自动化测试和 Web 数据抓取方面的工作。

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

医疗AI弹性计算指南:Holistic Tracking云端自动扩缩容应对门诊高峰

医疗AI弹性计算指南&#xff1a;Holistic Tracking云端自动扩缩容应对门诊高峰 引言 早上8点的三甲医院门诊大厅总是人满为患&#xff0c;挂号窗口排起长龙&#xff0c;诊室外坐满候诊患者。与此同时&#xff0c;支撑医院智能分诊、影像分析的AI系统也承受着巨大压力——响应…

作者头像 李华
网站建设 2026/3/26 21:20:22

成本控制十年演进

下面我从工程、系统与产业治理的角度&#xff0c;给你一条清晰的 「成本控制十年演进路线」。这不是财务视角的“省钱技巧”&#xff0c;而是成本控制范式如何随技术与系统复杂度演进。一、核心判断&#xff08;一句话&#xff09;未来十年&#xff0c;成本控制将从“预算约束”…

作者头像 李华
网站建设 2026/3/25 1:56:59

Holistic Tracking跨平台指南:Windows/Mac/Linux全兼容方案

Holistic Tracking跨平台指南&#xff1a;Windows/Mac/Linux全兼容方案 引言&#xff1a;为什么需要跨平台解决方案&#xff1f; 在现代混合办公环境中&#xff0c;团队成员可能使用Windows笔记本、MacBook或Linux工作站等各种设备。这种设备多样性带来了一个常见痛点&#x…

作者头像 李华
网站建设 2026/3/25 23:38:08

【数据库】【Mysql】慢SQL深度分析:EXPLAIN 与 optimizer_trace 全解析

MySQL 慢SQL深度分析&#xff1a;EXPLAIN 与 optimizer_trace 全解析 在 MySQL 性能优化体系中&#xff0c;慢SQL分析是核心技能。本文将从 EXPLAIN 执行计划解读 到 optimizer_trace 优化器追踪&#xff0c;构建完整的慢查询诊断方法论。一、EXPLAIN 基础与核心字段总览 1.1 E…

作者头像 李华
网站建设 2026/3/25 7:26:43

容器自动重启无效?深入剖析恢复机制失效的4大根源

第一章&#xff1a;容器故障自动恢复在现代云原生架构中&#xff0c;容器化应用的高可用性依赖于快速、可靠的故障自动恢复机制。Kubernetes 等容器编排平台通过内置控制器实现这一目标&#xff0c;确保服务在节点宕机、容器崩溃或资源不足时仍能持续运行。健康检查与重启策略 …

作者头像 李华
网站建设 2026/3/23 3:54:12

Holistic Tracking vs 传统动作捕捉实测对比:云端GPU 2小时搞定选型

Holistic Tracking vs 传统动作捕捉实测对比&#xff1a;云端GPU 2小时搞定选型 引言&#xff1a;虚拟主播技术选型的痛点 作为产品经理&#xff0c;当你需要为虚拟主播项目选择动作捕捉方案时&#xff0c;通常会面临两个选择&#xff1a;Holistic Tracking&#xff08;全身追…

作者头像 李华