如何使用Selenium浏览网页链接并返回

本文关键字:链接 返回 网页 浏览 何使用 Selenium | 更新日期: 2023-09-27 18:26:02

我正在尝试查找网页上的所有超链接,该网页的链接文本也在列表footerNames中。我想点击链接,等待(稍后会进行验证检查),导航回来,然后点击allLinksHrefs列表中的下一个链接(应该包含所有必要的网页链接元素)。目前我能够找到第一个链接,点击它,导航回来,但测试失败了。我使用的是带有C#的Selenium WebDriver。提前谢谢。

    public void TestFooterPageLinks()
    {
        List<IWebElement> allLinksHrefs = new List<IWebElement>();
        List<String> allLinksText = new List<String>();
        String currentUrl = Browser.Url;
        List<String> footerNames = new List<String>();
        footerNames.Add("About");
        footerNames.Add("Press");
        footerNames.Add("Safety");
        footerNames.Add("Privacy");
        footerNames.Add("Help");
        footerNames.Add("Terms");
        foreach (IWebElement link in Browser.FindElements(By.TagName("a")))
        {
            if (footerNames.Contains(link.Text))
            {
                if (allLinksHrefs.Contains(link)) {
                    continue;
                }
                else {
                    allLinksHrefs.Add(link);
                    Console.WriteLine(link);
                }
            }
        }
        foreach (IWebElement pageLink in allLinksHrefs)
        {
            Console.WriteLine(pageLink);
            pageLink.Click();
            Console.WriteLine(Browser.Title);
            Browser.Wait(3);
            Browser.Back();
        }
    }
}

如何使用Selenium浏览网页链接并返回

尝试用这种方式解决您的问题"导航回以前找到的元素将过期。因此,我们需要更新代码,以便在导航回后重新找到元素"

driver.navigate().to("http://www.example.com/");
List<WebElement> links = driver.findElements(By.tagName("a"));
System.out.println(links.size());
for(int i=0; i<links.size(); i++) {
    // Print the link text
    System.out.println(links.get(i).getText());
    // Print the href's
    System.out.println(links.get(i).getAttribute("href"));
    links.get(i).click();
    System.out.println(driver.getTitle());
    System.out.println(driver.getCurrentUrl());
    driver.navigate().back();
    /* after navigating back the elements found previously will be expired. 
       Hence we need to update the code to refind the elements after navigate back.
       so again we write the links = driver.findElements(By.tagName("a")); */
    links = driver.findElements(By.tagName("a"));
}

以下是我可能实现这一目标的方法:

List<WebElement> links = driver.findElements(By.cssSelector('a'));

以上内容让您

然后我可以看到几种不同的方法,我将概述一个微不足道的例子。

Iterator<WebElement> iter = links.iterator();

设置迭代器对象

while (iter.hasNext()) {
    WebElement we = iter.next();
    visitPage(we);
}

然后有支持的访问页面功能

public void visitPage(WebElement link) {
    try {
        link.click()
        Console.WriteLine("Visited Page: " + driver.getTitle() + " at url: " + link.text()); //for page title
    } catch (Exception e) {
        //do something clever with error handling
        e.printStackTrace();
    } 
    // navigate back
    driver.manage.navigate.back();  //go back to previous page (maybe don't even care about this)
}
  • 这是未经测试的