如何避免Puppeteer被前端JS检测

59次阅读

共计 615 个字符,预计需要花费 2 分钟才能阅读完成。

这两天开始看 puppeteer,发现居然也能被前端 js 检测出来!?
github 的 issue 区找了找,原来 puppeteer 启动的 chrome 里面,是有 navigator.webdriver 属性的,搞什么搞么,老外真是做那啥还要立牌坊 Orz
issue 里也看到了解决方案:

await this.page.evaluateOnNewDocument(() => {
         Object.defineProperty(navigator, 'webdriver', {get: () => undefined,
    });
 }

但是说实话这个还是有点问题的,因为用 "webdriver" in navigator 还是能检测出来。
想找找到底哪个环节把 ”webdriver” 属性加上的,但是文本搜索发现 puppeteer 源码中并没有……
后来发现是启动 chrome 的默认参数列表中有 ”–enable-automation”……
找了一下这个命令行参数的说明:

–enable-automation: Inform users that their browser is being controlled by an automated test.

妈蛋纯粹是立牌坊用的,其它毛用没有……
确认了就可以干掉它了,启动 chrome 时加个忽略默认参数即可:

const browser = await puppeteer.launch({ignoreDefaultArgs: ["--enable-automation"]});

正文完
 0