
本文介绍如何使用 seleniumbase 的 uc 模式替代原生 selenium,有效规避网站反爬与验证码拦截,实现 allegro 等电商平台商品列表页→编辑页→表单提交→关闭窗口的全流程稳定自动化操作。
现代电商平台(如 Allegro)普遍部署了先进的反自动化检测机制(如 Distil Networks、PerimeterX、Cloudflare Bot Management),原生 Selenium 极易因暴露 navigator.webdriver、特定 JS 环境特征、Chrome 未打补丁的指纹等被识别为机器人,导致触发 CAPTCHA、IP 封禁或请求限流。
你当前使用的 --disable-blink-features=AutomationControlled 和 excludeSwitches 等参数虽是基础防护,但已不足以应对主流风控系统——它们仅隐藏部分显性标志,却无法模拟真实用户行为链(如鼠标移动轨迹、键盘输入延迟、Canvas/WebGL 指纹随机化、WebRTC IP 泄露抑制等)。
✅ 推荐方案:SeleniumBase UC(Undetected Chromedriver)模式
SeleniumBase 内置的 uc=True 模式基于 undetected-chromedriver v2/v3 深度定制,自动完成以下关键伪装:
- 替换并混淆 WebDriver 属性(Object.defineProperty(navigator, 'webdriver', {value: undefined}))
- 注入随机化 Canvas/WebGL/Font 指纹
- 禁用 WebRTC IP 泄露、屏蔽 cdc_ 相关变量注入
- 启动时自动执行 10+ 项 Chrome 浏览器环境补丁
- 支持 uc_open_with_reconnect() 实现页面加载失败自动重试,避免因网络抖动被误判
安装与基础用法如下:
pip install seleniumbase
from seleniumbase import SB
# 启用 UC 模式,自动规避检测
with SB(uc=True, headless=False, uc_cdp=True) as sb:
# 安全访问目标站点(内置重连机制,最多尝试5次)
sb.driver.uc_open_with_reconnect("https://allegro.pl", 5)
# 模拟人工节奏:等待、滚动、悬停后点击
sb.sleep(3)
sb.scroll_to("a[data-box-name='MyOffers']")
sb.uc_click("a[data-box-name='MyOffers']", timeout=10)
# 进入商品列表后,循环处理第 n 个编辑按钮(示例:点击第1个)
edit_buttons = sb.find_elements("button:contains('EDYTUJ')")
if edit_buttons:
sb.uc_click(edit_buttons[0]) # 使用 uc_click 防止 click() 被拦截
# 切换到新弹出窗口(注意:Allegro 编辑页多为新 tab 或 iframe)
sb.switch_to_window(1) # 切至最新窗口
sb.wait_for_element_not_present("[aria-busy='true']", timeout=15)
# 安全填写表单(避免 send_keys 被识别为 bot 输入)
sb.type("#product-name-input", "PAKIET OCHRONY - GWARANCJA NA 2 LATA")
sb.select_option_by_text("#category-select", "Elektronika > Telefony i akcesoria")
sb.uc_click("#save-button")
# 关闭编辑页并返回主窗口
sb.driver.close()
sb.switch_to_window(0)
sb.sleep(2) # 人工间隔⚠️ 关键注意事项:
- 勿滥用 headless=True:UC 模式在无头模式下指纹仍可能异常,生产环境建议 headless=False + --window-size=1920,1080 模拟真实视口;
- 严格控制操作频率:每步操作间添加 sb.sleep(1.5–3),避免高频请求触发速率限制;
- 优先使用 uc_click() / uc_type():它们内部封装了防检测点击逻辑(如先 move_to_element 再 click),比原生 click() 更安全;
- 避免全局 time.sleep():改用 sb.sleep() 或 sb.wait_for_*(),确保 DOM 就绪后再操作;
- 会话复用更安全:若需长期运行,可保存 cookies 并复用登录态,减少重复登录带来的风控风险。
总结来说,与其手动拼凑零散的 ChromeOptions 参数,不如直接采用经过大规模验证的 UC 模式框架。它不仅解决了“能否通过检测”的问题,更提供了面向真实业务场景的 API 抽象(如 uc_open_with_reconnect、uc_click),让开发者专注业务逻辑而非对抗检测细节。对于 Allegro 这类高防护站点,这是目前 Python 生态中稳定性与开发效率兼顾的最佳实践路径。










