Chrome 特定功能

这些是 Google Chrome 浏览器特有的功能和特性。

默认情况下,Selenium 4 与 Chrome v75 及更高版本兼容。请注意,Chrome 浏览器的版本和 chromedriver 的版本必须匹配主版本。

选项

所有浏览器通用的功能在选项页面上描述。

Chrome 和 Chromium 特有的功能在 Google 的 Capabilities & ChromeOptions 页面上记录。

使用基本定义的选项启动 Chrome 会话如下所示

    ChromeOptions options = new ChromeOptions();
    driver = new ChromeDriver(options);
    options = webdriver.ChromeOptions()
    driver = webdriver.Chrome(options=options)
            var options = new ChromeOptions();
            driver = new ChromeDriver(options);
      options = Selenium::WebDriver::Options.chrome
      @driver = Selenium::WebDriver.for :chrome, options: options
    const Options = new Chrome.Options();
    let driver = new Builder()
      .forBrowser(Browser.CHROME)
      .setChromeOptions(Options)
      .build();

参数

args 参数用于在启动浏览器时使用的一系列命令行开关。 有两个很好的资源可以用来研究这些参数

常用的 args 包括 --start-maximized--headless=new--user-data-dir=...

向选项添加一个参数

    options.addArguments("--start-maximized");
    options.add_argument("--start-maximized")
            options.AddArgument("--start-maximized");
      options.args << '--start-maximized'
    let driver = new Builder()
      .forBrowser(Browser.CHROME)
      .setChromeOptions(options.addArguments('--headless=new'))
      .build();

在指定位置启动浏览器

binary 参数接受要使用的备用浏览器位置的路径。 通过此参数,您可以使用 chromedriver 来驱动各种基于 Chromium 的浏览器。

向选项添加浏览器位置

    options.setBinary(getChromeLocation());
    options.binary_location = chrome_bin
            options.BinaryLocation = GetChromeLocation();
      options.binary = chrome_location
    let driver = new Builder()
      .forBrowser(Browser.CHROME)
      .setChromeOptions(options.setChromeBinaryPath(`Path to chrome binary`))
      .build();

添加扩展程序

extensions 参数接受 crx 文件。至于解压缩的目录,请改用 load-extension 参数,如此帖子中所述。

向选项添加扩展程序

    options.addExtensions(extensionFilePath);
    options.add_extension(extension_file_path)
            options.AddExtension(extensionFilePath);
      options.add_extension(extension_file_path)
    const options = new Chrome.Options();
    let driver = new Builder()
      .forBrowser(Browser.CHROME)
      .setChromeOptions(options.addExtensions(['./test/resources/extensions/webextensions-selenium-example.crx']))
      .build();

保持浏览器打开

detach 参数设置为 true 将在进程结束后保持浏览器打开,只要没有向驱动程序发送 quit 命令。

注意:这已经是 Java 中的默认行为。

    options.add_experimental_option("detach", True)

注意:这已经是 .NET 中的默认行为。

      options.detach = true
    let driver = new Builder()
      .forBrowser(Browser.CHROME)
      .setChromeOptions(options.detachDriver(true))
      .build();

排除参数

Chromedriver 有几个默认参数用于启动浏览器。 如果您不希望添加这些参数,请将它们传递到 excludeSwitches 中。 一个常见的例子是重新打开弹出窗口拦截器。可以从Chromium 源代码中解析出完整的默认参数列表

在选项中设置排除的参数

    options.setExperimentalOption("excludeSwitches", List.of("disable-popup-blocking"));
    options.add_experimental_option('excludeSwitches', ['disable-popup-blocking'])
            options.AddExcludedArgument("disable-popup-blocking");
      options.exclude_switches << 'disable-popup-blocking'
    let driver = new Builder()
      .forBrowser(Browser.CHROME)
      .setChromeOptions(options.excludeSwitches('enable-automation'))
      .build();

服务

有关创建默认 Service 对象以及设置驱动程序位置和端口的示例,请参见驱动程序服务页面。

日志输出

获取驱动程序日志有助于调试问题。 Service 类允许您指定日志的输出位置。 除非用户将其定向到某个位置,否则日志输出将被忽略。

文件输出

要更改日志输出以保存到特定文件

    ChromeDriverService service =
        new ChromeDriverService.Builder().withLogFile(logLocation).build();

注意:Java 还允许通过系统属性设置文件输出
属性键:ChromeDriverService.CHROME_DRIVER_LOG_PROPERTY
属性值:表示日志文件路径的字符串

Selenium v4.11

    service = webdriver.ChromeService(log_output=log_path)
            service.LogPath = GetLogLocation();

控制台输出

要更改日志输出以在控制台中显示为 STDOUT

Selenium v4.10

    ChromeDriverService service =
        new ChromeDriverService.Builder().withLogOutput(System.out).build();

注意:Java 还允许通过系统属性设置控制台输出;
属性键:ChromeDriverService.CHROME_DRIVER_LOG_PROPERTY
属性值:DriverService.LOG_STDOUTDriverService.LOG_STDERR

Selenium v4.11

    service = webdriver.ChromeService(log_output=subprocess.STDOUT)

$stdout$stderr 都是有效值

Selenium v4.10

      service.log = $stdout

日志级别

有 6 个可用的日志级别:ALLDEBUGINFOWARNINGSEVEREOFF。请注意,--verbose 等效于 --log-level=ALL--silent 等效于 --log-level=OFF,因此此示例只是泛型地设置日志级别

Selenium v4.8

    ChromeDriverService service =
        new ChromeDriverService.Builder().withLogLevel(ChromiumDriverLogLevel.DEBUG).build();

注意:Java 还允许通过系统属性设置日志级别
属性键:ChromeDriverService.CHROME_DRIVER_LOG_LEVEL_PROPERTY
属性值:ChromiumDriverLogLevel 枚举的字符串表示形式

Selenium v4.11

    service = webdriver.ChromeService(service_args=['--log-level=DEBUG'], log_output=subprocess.STDOUT)

Selenium v4.10

      service.args << '--log-level=DEBUG'

日志文件功能

只有在记录到文件时才可用 2 个功能

  • 附加日志
  • 可读时间戳

要使用它们,您还需要显式指定日志路径和日志级别。日志输出将由驱动程序而不是进程管理,因此可能会出现细微的差异。

Selenium v4.8

    ChromeDriverService service =
        new ChromeDriverService.Builder().withAppendLog(true).withReadableTimestamp(true).build();

注意:Java 还允许通过系统属性切换这些功能
属性键:ChromeDriverService.CHROME_DRIVER_APPEND_LOG_PROPERTYChromeDriverService.CHROME_DRIVER_READABLE_TIMESTAMP
属性值:"true""false"

    service = webdriver.ChromeService(service_args=['--append-log', '--readable-timestamp'], log_output=log_path)

Selenium v4.8

      service.args << '--append-log'
      service.args << '--readable-timestamp'

禁用构建检查

Chromedriver 和 Chrome 浏览器版本应匹配,如果不匹配,驱动程序将出错。 如果禁用构建检查,则可以强制驱动程序与任何版本的 Chrome 一起使用。 请注意,这是一个不受支持的功能,不会调查错误。

Selenium v4.8

    ChromeDriverService service =
        new ChromeDriverService.Builder().withBuildCheckDisabled(true).build();

注意:Java 还允许通过系统属性禁用构建检查
属性键:ChromeDriverService.CHROME_DRIVER_DISABLE_BUILD_CHECK
属性值:"true""false"

Selenium v4.11

    service = webdriver.ChromeService(service_args=['--disable-build-check'], log_output=subprocess.STDOUT)
            service.DisableBuildCheck = true;

Selenium v4.8

      service.args << '--disable-build-check'

特殊功能

某些浏览器实现了它们特有的附加功能。

投屏

您可以驱动 Chrome Cast 设备,包括共享标签页

    List<Map<String, String>> sinks = driver.getCastSinks();
    if (!sinks.isEmpty()) {
      String sinkName = sinks.get(0).get("name");
      driver.startTabMirroring(sinkName);
      driver.stopCasting(sinkName);
    }
        sinks = driver.get_sinks()
        if sinks:
            sink_name = sinks[0]['name']
            driver.start_tab_mirroring(sink_name)
            driver.stop_casting(sink_name)
      sinks = @driver.cast_sinks
      unless sinks.empty?
        device_name = sinks.first['name']
        @driver.start_cast_tab_mirroring(device_name)
        expect { @driver.stop_casting(device_name) }.not_to raise_exception
      end

网络条件

您可以模拟各种网络条件。

    ChromiumNetworkConditions networkConditions = new ChromiumNetworkConditions();
    networkConditions.setOffline(false);
    networkConditions.setLatency(java.time.Duration.ofMillis(20)); // 20 ms of latency
    networkConditions.setDownloadThroughput(2000 * 1024 / 8); // 2000 kbps
    networkConditions.setUploadThroughput(2000 * 1024 / 8);   // 2000 kbps

    ((ChromeDriver) driver).setNetworkConditions(networkConditions);
    network_conditions = {
        "offline": False,
        "latency": 20,  # 20 ms of latency
        "download_throughput": 2000 * 1024 / 8,  # 2000 kbps
        "upload_throughput": 2000 * 1024 / 8,    # 2000 kbps
    }
    driver.set_network_conditions(**network_conditions)
      @driver.network_conditions = {offline: false, latency: 100, throughput: 200}

日志

    LogEntries logs = driver.manage().logs().get(LogType.BROWSER);
    logs = driver.get_log("browser")
      logs = @driver.logs.get(:browser)

权限

    driver.setPermission("camera", "denied");
    driver.set_permissions('camera', 'denied')
      @driver.add_permission('camera', 'denied')
      @driver.add_permissions('clipboard-read' => 'denied', 'clipboard-write' => 'prompt')

DevTools

有关使用 Chrome DevTools 的更多信息,请参见Chrome DevTools部分