news 2026/5/1 8:33:25

使用 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/5/1 6:15:53

质量控制十年演进

下面给你一条从专业工程与系统治理视角出发的「质量控制十年演进路线」。我会刻意避开泛泛而谈&#xff0c;把重点放在控制范式如何变化、为什么会变化、以及哪些能力会成为分水岭。一、核心判断&#xff08;一句话&#xff09;未来十年&#xff0c;质量控制将从“事后检测”演…

作者头像 李华
网站建设 2026/5/1 3:43:40

Proteus元件库对照表在双列直插封装中的应用指南

如何用好 Proteus 元件库对照表&#xff1f;DIP 封装设计避坑全指南你有没有遇到过这种情况&#xff1a;在 Proteus 里画完一个基于 AT89C51 的最小系统&#xff0c;仿真一跑&#xff0c;LED 不闪、时钟没波形——查了半天才发现&#xff0c;原来调用的芯片封装是 SOIC&#xf…

作者头像 李华
网站建设 2026/4/20 1:21:15

老年人也能学会:MediaPipe Holistic图形界面版云端体验

老年人也能学会&#xff1a;MediaPipe Holistic图形界面版云端体验 引言&#xff1a;当太极拳遇上AI 退休工程师张师傅最近迷上了太极拳&#xff0c;但总担心自己的动作不够标准。传统方法要么需要专业教练指导&#xff0c;要么得反复观看录像对比——直到他发现了MediaPipe …

作者头像 李华
网站建设 2026/4/29 17:07:52

MediaPipe Holistic开箱即用镜像:0配置体验全身540个关键点追踪

MediaPipe Holistic开箱即用镜像&#xff1a;0配置体验全身540个关键点追踪 引言&#xff1a;为什么你需要这个镜像&#xff1f; 如果你正在开发AR应用、健身分析系统或手势交互项目&#xff0c;一定遇到过这些头疼问题&#xff1a;GitHub下载的MediaPipe Holistic代码跑不起…

作者头像 李华
网站建设 2026/5/1 7:22:21

3D电商模特生成术:Holistic Tracking+云端GPU,1小时出样片

3D电商模特生成术&#xff1a;Holistic Tracking云端GPU&#xff0c;1小时出样片 1. 为什么服装店主需要AI模特生成&#xff1f; 对于中小服装店主来说&#xff0c;每次上新都要请专业模特拍摄是一笔不小的开支。传统拍摄流程需要预约模特、摄影师、场地&#xff0c;后期还要…

作者头像 李华
网站建设 2026/5/1 7:35:48

中小企业AI语音落地指南:VibeVoice镜像省钱实战方案

中小企业AI语音落地指南&#xff1a;VibeVoice镜像省钱实战方案 1. 引言&#xff1a;中小企业为何需要高效TTS解决方案 在内容创作、客户服务、教育产品等场景中&#xff0c;高质量的语音合成&#xff08;Text-to-Speech, TTS&#xff09;正成为提升用户体验的核心能力。然而…

作者头像 李华