Как извлечь исходный код страницы через исполнителя Javascript?

import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.JavascriptExecutor;
import org.openqa.selenium.WebDriver;       

public class oo {
   public static void main(String[] args) {

       System.setProperty("webdriver.chrome.driver","D:\\Java\\Lib\\chromedriver.exe");
      WebDriver driver = new ChromeDriver();         
      driver.navigate().to("https://google.com");

      JavascriptExecutor js = (JavascriptExecutor) driver;  
      Object s = js.executeScript("return document.body.innerHTML;",null).toString();

      System.out.println(s);
      driver.close();
   }
}

Выше код возвращает nullPointerException.

Exception in thread "main" java.lang.NullPointerException at java.util.Arrays.stream(Unknown Source) at java.util.stream.Stream.of(Unknown Source) at org.openqa.selenium.remote.RemoteWebDriver.executeScript(RemoteWebDriver.java:484) at oo.main(oo.java:25)

Когда я удаляю необязательный параметр объекта, то идет ошибка компиляции.

Код:

  JavascriptExecutor js = (JavascriptExecutor) driver;  
  Object s = js.executeScript("return document.body.innerHTML;").toString();

Ошибка:

Exception in thread "main" java.lang.Error: Unresolved compilation problem:     The method executeScript(String, Object[]) in the type JavascriptExecutor is not applicable for the arguments (String)

Использование Selenium-server-standalone-3.141.59.jar

1 ответ

Чтобы извлечь и распечатать исходный код страницы через JavascriptExecutor, вы можете использовать следующее (на основе Java) решение:

  • Синтаксис:

    String page_source = ((JavascriptExecutor)driver).executeScript("return document.documentElement.innerHTML;").toString();
    System.out.println(page_source);
    

Примечание. Перед извлечением источника страницы вам нужно заставить официанта полностью загрузить страницу.

Другие вопросы по тегам