如何通过 Hotwire Turbo 流正确渲染图像?

How do I correctly render images via Hotwire Turbo streams?

我的问题:使用 Hotwire/Turbo 渲染图像时,所有 URL 都使用主机 example.org 而不是我的实际主机名进行渲染。常规视图很好,但通过 Turbo 流渲染局部视图会导致 ActiveStorage URLs,如 http://example.org/.../.

上下文:我有一个简单的 Todo 应用程序,有一个工作视图、部分视图和 turbo 流,它们一起显示一个 Todo 和一个关联用户列表。当我将用户加入 Todo 时,turbo 流呈现正确的部分,并将用户名和头像放在我想要的 DOM 中。但是,来自 ActiveStorage 的映像 URL 包含 example.org 主机名。

我在 config/environments/*.rb 中设置了我的标准 URL 选项,包括 routes.default_url_options[:host]config.action_mailer.default_url_options[:host]。我还了解了文件 config/initializers/application_controller_renderer.rb,您可以在其中设置一个 http_host 参数;然而,我设置了 http_hosthttps 布尔值,Turbo 仍然用 example.org.

渲染我的 image_tag

此外,我发现关于如何以编程方式操作默认渲染器(以解决问题)的建议有限。 This source 表示抓取 ApplicationController.renderer 并覆盖属性,如下所示:

renderer = ApplicationController.renderer.new(
  http_host: request.host_with_port,
  https: (request.protocol == "https://"),
  "rack.session": request.session
)

但是 broadcast_action_to 方法似乎不接受 renderer 参数,所以这在 Turbo 中实际上对我没有帮助。

肯定有一个配置是我遗漏的,但我没有在 Turbo 或 Hotwire 文档中找到它。

我失踪了config.action_controller.default_url_options。一旦我将其配置为与其他 default_url_options 相同,我的链接便开始正确呈现。