news 2026/4/24 20:33:47

使用 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/4/18 0:14:41

零配置开箱即用:AI智能文档扫描仪让办公更高效

零配置开箱即用&#xff1a;AI智能文档扫描仪让办公更高效 1. 背景与痛点分析 在现代办公场景中&#xff0c;纸质文档的数字化处理已成为高频需求。无论是合同签署、发票报销&#xff0c;还是会议白板记录&#xff0c;用户常常需要将物理文档快速转化为清晰、可存档的电子文件…

作者头像 李华
网站建设 2026/4/17 19:12:09

没独显怎么跑MediaPipe Holistic?云端GPU1小时1块,小白友好

没独显怎么跑MediaPipe Holistic&#xff1f;云端GPU1小时1块&#xff0c;小白友好 引言&#xff1a;零门槛玩转AI动作捕捉 想象一下&#xff0c;在体育课上用AI分析学生投篮姿势&#xff0c;或是在舞蹈课上实时捕捉动作轨迹——这就是MediaPipe Holistic的魅力。这个由谷歌开…

作者头像 李华
网站建设 2026/4/23 13:50:42

AI全身追踪省钱攻略:比买动捕设备省90%,按需付费不浪费

AI全身追踪省钱攻略&#xff1a;比买动捕设备省90%&#xff0c;按需付费不浪费 1. 为什么舞蹈工作室需要AI动作捕捉 对于舞蹈工作室来说&#xff0c;录制学员的3D动作视频是提升教学质量和展示效果的重要手段。传统方案需要租赁专业动作捕捉设备&#xff0c;每月费用高达6000…

作者头像 李华
网站建设 2026/4/20 11:28:53

5步搞定MediaPipe Holistic:云端镜像免配置,比本地快3倍

5步搞定MediaPipe Holistic&#xff1a;云端镜像免配置&#xff0c;比本地快3倍 1. 为什么选择云端运行MediaPipe Holistic&#xff1f; MediaPipe Holistic是谷歌推出的实时人体姿态检测模型&#xff0c;能同时追踪面部、手部和身体的540多个关键点。对于想开发体感游戏、健…

作者头像 李华
网站建设 2026/4/18 10:07:19

氛围编程安全六大核心原则:理论架构、技术落地与未来防御体系

在大模型、智能体与低代码平台深度融合的当下&#xff0c;氛围编程作为一种全新的人机协同研发模式应运而生——它以自然语言为交互媒介&#xff0c;依托智能模型的生成能力与智能体的资源调度能力&#xff0c;实现需求到代码的快速转化&#xff0c;大幅提升研发效率。但与此同…

作者头像 李华