在Puppeteer Sharp中完成程序后如何停止关闭浏览器

时间:2020-09-13 03:02:21

标签: c# puppeteer puppeteer-sharp

我们正在为客户提供密码管理解决方案。我们可以使用以下代码使用puppeter sharp成功地使用户名和密码自动化。

但是在程序执行后,浏览器会自动关闭。无论如何,在程序执行后是否可以使浏览器继续运行。

static async Task Main(string[] args)
        {
            var options = new LaunchOptions { Headless = false, ExecutablePath = "C:\\Program Files (x86)\\Google\\Chrome\\Application\\chrome.exe", Args = new string[] { "--no-sandbox" } };

            using (var browser = await Puppeteer.LaunchAsync(options))
            using (var page = await browser.NewPageAsync())
            {
                // use page
                await page.GoToAsync("https://accounts.google.com/");
                //await page.WaitForNavigationAsync();

                // await page.WaitForSelectorAsync("type=email");
                //  await page.ClickAsync("type=email");

                //  await page.WaitForNavigationAsync();
                await Task.Delay(2000);
                //TODO : change to your email
                await page.TypeAsync("#identifierId", "someusername@gmail.com");
                await page.WaitForSelectorAsync("#identifierNext");
                await page.ClickAsync("#identifierNext");
                await Task.Delay(2000);

                await page.WaitForSelectorAsync(@"input[type='password']");
                await Task.Delay(2000);
                await page.ClickAsync(@"input[type='password']");
                await Task.Delay(2000);

                //TODO : change to your password
                await page.TypeAsync(@"input[name='password']", "somepassword");
                await Task.Delay(2000);
                await page.WaitForSelectorAsync("#passwordNext");
                await Task.Delay(2000);
                await page.ClickAsync("#passwordNext");
                await Task.Delay(2000);
                await page.WaitForNavigationAsync();
            }
        }

1 个答案:

答案 0 :(得分:0)

如果要自动化浏览器,然后将其打开以进行用户交互,则需要先启动浏览器 ,然后才能将其自动化,并将代码附加到该浏览器实例。这个问题提供了一些有关如何执行此操作的信息:

Puppeteer C#: Connecting to Running Chrome Instance

本文将对该策略进行更详细的介绍:

https://medium.com/@jaredpotter1/connecting-puppeteer-to-existing-chrome-window-8a10828149e0

相关问题