gpt4 book ai didi

java - selenium + java - 如何下载 pdf 并用不同的名称保存?

转载 作者:行者123 更新时间:2023-12-02 01:59:03 27 4
gpt4 key购买 nike

作为现有 selenium 测试包工作的一部分,我被要求删除 Firefox 的实例以下载服务器生成的 PDF 文档 - 身份验证问题导致代理配置 session 错误,导致无法下载文档。

在服务器中生成文档后,可以通过包含 UUID 的 URL 访问它。此 URL 已传递到 Firefox 的新实例,并且可以下载该文档。

这个 selenium 包是根据大约 10 年前软件开发的最佳实践拼凑在一起的。虽然它有效,但在大多数情况下,它的性能很差。

我可以使用服务 URL 加上 UUID 作为路径的一部分来访问服务器上生成的文档,因为这是文档生成过程的一部分。在当前的工作流程中,有一个“生成文档”按钮,运行包会点击该按钮。

生成此文档后,我需要将其下载到特定文件夹并重命名,以证明该过程已圆满完成。

我进行了大量搜索,找到了几篇文章,这些文章让我对问题的部分内容有了深入的了解,但无法形成一个可行的解决方案。

我可以在 headless 模式下启动 chrome 驱动程序,但还没有弄清楚如何下载文档。由于浏览器窗口显示文档本身,因此页面上没有可点击的下载按钮。

谁能指出我的解决方案?

提前致谢

最佳答案

当前,在 chrome 中打开 pdf 时,我们可以看到下载选项,但通过 selenium 我们无法对该下载按钮执行任何操作。这里我们的目标是将 pdf 下载到所需位置,因此我们需要在启动驱动程序之前禁用 pdf 插件。请看下面的代码,

必需的 ChromOptions:

   ChromeOptions options = new ChromeOptions();
HashMap<String, Object> chromeOptionsMap = new HashMap<String, Object>();
chromeOptionsMap.put("plugins.plugins_disabled", new String[] { "Chrome PDF Viewer" });
chromeOptionsMap.put("plugins.always_open_pdf_externally", true);
chromeOptionsMap.put("download.default_directory", "C:\\Users\\Downloads\\test\\");
options.setExperimentalOption("prefs", chromeOptionsMap);
options.addArguments("--headless");

访问 PDF:

driver = new ChromeDriver(options);
driver.manage().deleteAllCookies();
driver.get("C:\\Users\\Downloads\\Bill.pdf");

说明:

plugins.plugins_disabled --> 禁用在 chrome 中查看 pdf

plugins.always_open_pdf_externally --> 在启动相应链接或 URI 时下载 pdf .

download.default_directory --> 可以更改默认下载位置。

关于java - selenium + java - 如何下载 pdf 并用不同的名称保存?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69251242/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com