1

是否可以从加载时间>=1 秒的 .HAR 中过滤请求/响应?我需要将 har 对象保存到单独的文件中并上传到 har 查看器。下面是我生成 .HAR 文件的代码。

//BrowserMobProxy
        BrowserMobProxy server = new BrowserMobProxyServer();
        server.start(0);
        server.setHarCaptureTypes(CaptureType.getAllContentCaptureTypes());
        server.enableHarCaptureTypes(CaptureType.REQUEST_CONTENT, CaptureType.RESPONSE_CONTENT);
        server.newHar("Bhaskar");

        //PHANTOMJS_CLI_ARGS
        ArrayList<String> cliArgsCap = new ArrayList<>();
        cliArgsCap.add("--proxy=localhost:"+server.getPort());
        cliArgsCap.add("--ignore-ssl-errors=yes");

        //DesiredCapabilities
        String userAgent = "Mozilla/5.0 (Linux; Android 5.0; SM-G900P Build/LRX21T) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94 Mobile Safari/537.36";
        DesiredCapabilities capabilities = new DesiredCapabilities();
        capabilities.setCapability(CapabilityType.ACCEPT_SSL_CERTS, true);
        capabilities.setCapability(CapabilityType.SUPPORTS_JAVASCRIPT, true);
        capabilities.setCapability("phantomjs.page.settings.userAgent", userAgent);
        capabilities.setCapability(PhantomJSDriverService.PHANTOMJS_CLI_ARGS, cliArgsCap);
        capabilities.setCapability(PhantomJSDriverService.PHANTOMJS_EXECUTABLE_PATH_PROPERTY,"D:/req/phantomjs-2.1.1-windows/bin/phantomjs.exe");

        //WebDriver
        WebDriver driver = new PhantomJSDriver(capabilities);
        driver.get("https://www.google.com");

        //HAR
        Har har = server.getHar();
        FileOutputStream fos = new FileOutputStream("D:\\HAR-Information.har");
        har.writeTo(fos);
        server.stop();
        driver.close();
4

1 回答 1

1

您是否注意到 HAR 中的“计时”块?

该对象描述了请求-响应往返过程中的各个阶段。所有时间都以毫秒为单位指定。

"timings": {
    "blocked": 0,
    "dns": -1,
    "connect": 15,
    "send": 20,
    "wait": 38,
    "receive": 12,
    "ssl": -1,
    "comment": ""
}
  • 阻塞 [数字,可选] - 在队列中等待网络连接所花费的时间。如果时间不适用于当前请求,请使用 -1。

  • dns [数字,可选] - DNS 解析时间。解析主机名所需的时间。如果时间不适用于当前请求,请使用 -1。

  • connect [number, optional] - 创建 TCP 连接所需的时间。如果时间不适用于当前请求,请使用 -1。

  • send [number] - 向服务器发送 HTTP 请求所需的时间。

  • wait [number] - 等待来自服务器的响应。receive [number] - 从服务器(或缓存)读取整个响应所需的时间。

  • ssl [数字,可选](1.2 中的新功能)- SSL/TLS 协商所需的时间。如果定义了此字段,则时间也包含在连接字段中(以确保与 HAR 1.1 的向后兼容性)。如果时间不适用于当前请求,请使用 -1。

  • 注释 [字符串,可选](1.2 中的新功能)- 用户或应用程序提供的注释。

发送、等待和接收时间不是可选的,并且必须具有非负值。

如果无法提供每个请求的阻塞、dns、connect 和 ssl 计时,导出工具可以省略它们。如果不适用,可以提供这些计时的工具可以将其值设置为 -1。例如,对于重用现有连接的请求,connect 将为 -1。

请求的时间值必须等于本节中提供的时间之和(不包括任何 -1 值)。

如果没有 -1 值(条目是 log.entries 中的对象),则以下必须为真:

entry.time == entry.timings.blocked + entry.timings.dns + entry.timings.connect + entry.timings.send + entry.timings.wait + entry.timings.receive;

一旦你有了完整的 HAR 对象,你就可以遍历 HAR 并计算每个元素的总项,并删除那些时间>1000ms 的项。然后您可以将 HAR 对象保存到文件中。

于 2017-12-12T06:14:15.283 回答