我将该命令放在windows bash shell中,以便使用指定的chrome-profile启动chrome
start chrome --remote-debugging-port="${browserId}" --profile-directory="${task.profile}"
接下来:我启动puppeteer并尝试连接到现有的浏览器,puppeteer打开两个浏览器窗口。第一个有指定的chrome-profile,第二个有默认的profile,所有的自动化任务都是在这里完成的。如何确保puppeteer使用具有指定chrome-profile的第一个窗口
const browser = await puppeteer.connect({browserURL: `http://127.0.0.1:${task.browser}`, defaultViewport:null})
发布于 2020-06-21 21:58:07
如果不是必须从bash启动chrome,但可以通过Node脚本本身启动,那么您可以尝试以下方法。(在我的示例中,我使用websocket endpoint而不是browserUrl来连接,请随意选择更适合您的需求。)
const browser = await puppeteer.launch({
headless: true,
args: [
`--user-data-dir=${task.profile}`
]
})
const browserWSEndpoint = await browser.wsEndpoint()
const browser2 = await puppeteer.connect({ browserWSEndpoint, defaultViewport: null })注意:确保您的--user-data-dir是正确的。如果你在Windows上,你将需要类似于:'--user-data-dir=%userprofile%\\AppData\\Local\\Google\\Chrome\\User Data\\ProfileName'
要确定正在运行的Chrome实例的用户数据目录:
导航到chrome://version
Profile Path字段。这提供了配置文件directory.示例(Windows):
C:\Users\Alice\AppData\Local\Google\Chrome\User Data\Default
C:\Users\Alice\AppData\Local\Google\Chrome\User Data的
发布于 2020-06-22 19:04:07
所以我找到了解决方案:首先,我连接到现有的浏览器const browser = await puppeteer.connect({browserURL:http://127.0.0.1:port, defaultViewport:null}),然后调用:const page = await browser.newPage(),这是两个浏览器窗口打开的地方。所以我所做的是在连接到现有的浏览器之后。我获得了所有打开的页面let pages = await browser.pages(),然后选择了第一个页面let page = pages[0],所以现在puppeteer使用带有所选配置文件的第一个浏览器窗口。我不明白的是,为什么const page = await browser.newPage()要打开一个新的浏览器窗口,而不是在同一个浏览器窗口中打开一个新页面。因此,解决方案是这样的:
const browser = await puppeteer.connect({browserURL: http://127.0.0.1:${task.browser}, defaultViewport:null})
let pages = await browser.pages()
let page = pages[0]
await page.goto(url)https://stackoverflow.com/questions/62488121
复制相似问题