在streetmerchant项目中实现Chromium无头模式下持久化Cookie设置的技术方案
2025-06-07 07:37:22作者:凌朦慧Richard
背景介绍
streetmerchant是一个基于Node.js和Puppeteer的电商商品库存监控工具,它使用Chromium浏览器自动化技术来抓取各大电商网站的商品信息。在实际使用过程中,用户发现某些电商网站(如Newegg)会通过Cookie识别爬虫行为并返回403错误或验证码。
问题分析
经过用户测试发现,当Chromium浏览器设置为"阻止所有Cookie"时,可以有效避免被目标网站识别为爬虫。这是因为:
- 阻止Cookie后网站无法建立用户会话跟踪
- 每次访问都被视为首次访问,降低了触发反爬机制的概率
- 避免了基于Cookie的行为分析
当前streetmerchant的主要限制在于:
- 无法在无头模式下持久化Cookie设置
- 每次启动都会重置浏览器设置
- 现有隐身模式(INCOGNITO)仅阻止第三方Cookie,无法完全禁用所有Cookie
技术解决方案
方案一:使用持久化用户数据目录
通过Puppeteer启动参数配置持久化的用户数据目录,可以保存浏览器设置:
args.push('--user-data-dir=/path/to/profile');
args.push('--disable-dev-profile');
这种方法:
- 创建固定位置的用户配置文件
- 禁用开发人员配置文件(避免设置重置)
- 允许手动配置浏览器设置并保持
方案二:通过Puppeteer API设置Cookie策略
虽然Puppeteer没有直接设置"阻止所有Cookie"的API,但可以通过以下方式间接实现:
- 启动时设置内容设置规则:
await client.send('Network.setCookieBlockingEnabled', {
enabled: true
});
- 或者通过Protocol直接修改内容设置:
await client.send('Browser.setPermission', {
origin: '',
setting: 'block'
});
方案三:拦截和清除网络请求中的Cookie
可以在页面加载前清除所有Cookie:
await page.setRequestInterception(true);
page.on('request', request => {
const headers = request.headers();
delete headers['cookie'];
request.continue({headers});
});
实现建议
对于streetmerchant项目,推荐采用以下改进方案:
-
扩展环境变量配置,增加:
USER_DATA_DIR:自定义用户数据目录路径BLOCK_ALL_COOKIES:完全阻止Cookie的开关
-
修改浏览器启动逻辑,根据配置:
- 设置持久化用户目录
- 应用Cookie阻止策略
- 确保无头模式兼容性
-
增加启动时的Cookie清理功能:
const client = await page.target().createCDPSession(); await client.send('Network.clearBrowserCookies'); await client.send('Network.clearBrowserCache');
注意事项
- 不同网站对无Cookie访问的反应不同,需测试调整
- 持久化用户目录会增加磁盘使用
- 完全阻止Cookie可能影响某些网站功能
- 需要平衡反爬规避与合法爬取边界
总结
通过合理配置Chromium的用户数据目录和Cookie策略,可以在streetmerchant项目中实现更稳定的爬取体验。这些技术方案不仅适用于Newegg,也可扩展到其他具有类似反爬机制的电商网站。开发者可以根据实际需求选择最适合的实现方式,或组合多种技术来达到最佳效果。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0138- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
MiniCPM-V-4.6这是 MiniCPM-V 系列有史以来效率与性能平衡最佳的模型。它以仅 1.3B 的参数规模,实现了性能与效率的双重突破,在全球同尺寸模型中登顶,全面超越了阿里 Qwen3.5-0.8B 与谷歌 Gemma4-E2B-it。Jinja00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00
MusicFreeDesktop插件化、定制化、无广告的免费音乐播放器TypeScript00
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
726
4.66 K
Ascend Extension for PyTorch
Python
597
750
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
427
377
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
992
986
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
993
138
昇腾LLM分布式训练框架
Python
161
190
暂无简介
Dart
969
246
deepin linux kernel
C
29
16
Oohos_react_native
React Native鸿蒙化仓库
C++
345
393
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.65 K
970