C# Selenium Firefox - 错误异常"Browsing context has been discarded"



我正在编写一个程序,可以帮助我的客户从网站下载发票PDF,第一次使用drv.Navigate().GoToUrl(URL);时一切正常。之后,程序休眠一段时间,清醒时开始搜索我的客户的电子邮件(使用 S22 DLL(,如果他找到某封电子邮件,则从电子邮件中提取链接并使用(第二次(drv.Navigate().GoToUrl(URL);。但这次我得到了一个例外

浏览上下文已被丢弃

我已经尝试了一切可能的方法,但最"震惊"的是,我在 Google 上找不到有关此错误的任何内容,也没有在 Selenium 文档中找到任何内容。

我不明白是什么意思

我确定该链接有效,因为是相同的链接。

下面受此问题影响的代码

PS:第一次下载与第二次下载完全相同

public static int Go(string URL, ImapClient EmailClient, uint mUID, bool isFromOutlook) {
// While the Firefox driver isn't initialized, wait for it
while (isDrvInit != 1 && isDrvInit != 2)
Thread.Sleep(1);
// If the Firefox driver was not able to initialize, we can't procede further
if (isDrvInit == 2)
return 0;
try {
drv.Navigate().GoToUrl(URL); // Here the program throw the exception
if (isLoginPage()) {
if (!Login()) {
if (Internet.IsAvailable()) {
Error.Show(Error.Code.MOBILCOM_LOGIN, Error.Status.F, Error.Type.DEFAULT,
"Unable to log-in to the Mobilcom account... Are the e-mail/password in the config file correct?");
} else {
Error.Show(Error.Code.FIREFOX_CANT_NAVIGATE, Error.Status.W, Error.Type.DEFAULT, String.Format(
"Can't connect to Mobilcom because Internet connection is missing...", drv.Url));
}
return 0;
} else {
Error.Show(Error.Code.MOBILCOM_LOGIN, Error.Status.S, Error.Type.DEFAULT,
"Successfully logged to the Mobilcom account!");
if (GetPdfInvoice() == true) {
if (isFromOutlook) {
MailMessage _m = EmailClient.GetMessage(mUID, true, Global.outlookSpecialFolder);
Error.Show(Error.Code._DEFAULT, Error.Status.S, Error.Type.OUTLOOK, String.Format(
"PDF Invoice: Subject: [{0}] | Downloaded from the link '{1}' successfully saved! :)",
_m.Subject, drv.Url));
} else {
MailMessage _m = EmailClient.GetMessage(mUID, true, Global.gmailSpecialFolder);
Error.Show(Error.Code._DEFAULT, Error.Status.S, Error.Type.GMAIL, String.Format(
"PDF Invoice: Subject: [{0}] | Downloaded from the link '{1}' successfully saved! :)",
_m.Subject, drv.Url));
}
} else {
if (!Internet.IsAvailable()) {
Error.Show(Error.Code.MOBILCOM_NO_INTERNET, Error.Status.W, Error.Type.DEFAULT, String.Format(
"Can't download the PDF Invoice from '{0}' because Internet connection is missing!",
drv.Url));
} else {
Error.Show(Error.Code.MOBILCOM_CANT_D_PDF, Error.Status.F, Error.Type.DEFAULT, String.Format (
"Unknow Exception: Can't download the PDF Invoice from '{0}', retrying to download next time...",
drv.Url));
}
}
CloseUnnecessaryTabs();
}
} else {
// Still nothing
}
return 1;
} catch {
if (!Internet.IsAvailable()) {
Error.Show(Error.Code.FIREFOX_CANT_NAVIGATE, Error.Status.W, Error.Type.DEFAULT, String.Format(
"Unable to continue on Mobilcom because Internet connection is missing, retrying to download next time..."));
} else {
Error.Show(Error.Code.FIREFOX_CANT_NAVIGATE, Error.Status.F, Error.Type.DEFAULT, String.Format(
"Unknow Exception: Unable to reach the '{0}' URL", drv.Url));
}
CloseUnnecessaryTabs();
return 0;
}
}

[编辑]

CloseUnnecessaryTabs()代码关闭每个打开的选项卡,只留下一个以避免关闭 Firefox

private static void CloseUnnecessaryTabs() {
if (drv.WindowHandles.Count > 1) {
for (int i = drv.WindowHandles.Count - 1; i > 0; i--) {
drv.SwitchTo().Window(drv.WindowHandles[i]);
drv.Close();
}
}
}

我在代码中发现了导致此异常的错误。

关闭不必要的选项卡后,我忘记切换回"main"选项卡,我已经解决了向CloseUnnecessaryTabs()代码添加drv.SwitchTo().Window(drv.WindowHandles[0]);的问题。

private static void CloseUnnecessaryTabs() {
if (drv.WindowHandles.Count > 1) {
for (int i = drv.WindowHandles.Count - 1; i > 0; i--) {
drv.SwitchTo().Window(drv.WindowHandles[i]);
drv.Close();
}
}
drv.SwitchTo().Window(drv.WindowHandles[0]); // <-- The solution
}

我在这里找到了一个"提示"

每个浏览上下文都有一个关联的已知元素列表。丢弃浏览上下文时,已知元素的列表也会随之丢弃。

最新更新