相关文章推荐
潇洒的硬币  ·  winform 调用 js - ...·  1 年前    · 
气宇轩昂的香瓜  ·  ora-01013 user ...·  1 年前    · 
Collectives™ on Stack Overflow

Find centralized, trusted content and collaborate around the technologies you use most.

Learn more about Collectives

Teams

Q&A for work

Connect and share knowledge within a single location that is structured and easy to search.

Learn more about Teams

I've got two issues that I can't solve it at them moment.

1. I would like to keep the browser running so I could just re-connect using pyppeteer.launcher.connect() function but it seems to be closed imidiately even if I don't call pyppeteer.browser.Browser.close() .

test01.py:

import asyncio
from pyppeteer import launch, connect
async def fetch():
    browser = await launch(
        headless=False,
        args=['--no-sandbox']
    print(f'Endpoint: {browser.wsEndpoint}')
    await browser.disconnect()
loop = asyncio.get_event_loop()
loop.run_until_complete(fetch())
$ python test01.py
Endpoint: ws://127.0.0.1:51757/devtools/browser/00e917a9-c031-499a-a8ee-ca4090ebd3fe
$ curl -i -N -H "Connection: Upgrade" -H "Upgrade: websocket" http://127.0.0.1:51757
curl: (7) Failed to connect to 127.0.0.1 port 51757: Connection refused

2. How do I create CDP session. This code should open another browser window but it doesn't work as expected:

test02.py

import asyncio
import time
from pyppeteer import launch, connect
async def fetch():
    browser = await launch(
        headless=False,
        args=['--no-sandbox']
    page = await browser.newPage()
    cdp = await page.target.createCDPSession()
    await cdp.send('Target.createBrowserContext')
    time.sleep(5)
    await browser.disconnect()
loop = asyncio.get_event_loop()
loop.run_until_complete(fetch())
$ python test02.py
Future exception was never retrieved
future: <Future finished exception=NetworkError('Protocol error Target.sendMessageToTarget: Target closed.',)>
pyppeteer.errors.NetworkError: Protocol error Target.sendMessageToTarget: Target closed.
  

autoClose (bool): Automatically close browser process when script completed. Defaults to True.

In this case you test01.py would look as follows:

import asyncio
from pyppeteer import launch, connect
async def fetch():
    browser = await launch(
        headless=False,
        args=['--no-sandbox'],
        autoClose=False
    print(f'Endpoint: {browser.wsEndpoint}')
    await browser.disconnect()
loop = asyncio.get_event_loop()
loop.run_until_complete(fetch())

CDP session

Here it is:

import asyncio
import time
from pprint import pprint
from pyppeteer import launch, connect
from pyppeteer.browser import BrowserContext
async def fetch():
    browser = await launch(
        headless=False,
        args=['--no-sandbox'],
        autoClose=False
    page = await browser.newPage()
    cdp = await page.target.createCDPSession()
    raw_context = await cdp.send('Target.createBrowserContext')
    pprint(raw_context)
    context = BrowserContext(browser, raw_context['browserContextId'])
    new_page = await context.newPage()
    await cdp.detach()
    await browser.disconnect()
loop = asyncio.get_event_loop()
loop.run_until_complete(fetch())

Inspired by Browser.createIncognitoBrowserContext from pyppeteer itself. Notice creating additional sessions via CDP doesn't seem to be such a great idea because browser._contexts won't be updated and will become inconsistent. It's also likely that Browser.createIncognitoBrowserContext might fit your needs without resorting to CDP whatsoever

Thanks for contributing an answer to Stack Overflow!

  • Please be sure to answer the question. Provide details and share your research!

But avoid

  • Asking for help, clarification, or responding to other answers.
  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.