java - PrimeFaces 8.0 DefaultStreamedContent.builder().stream() 要求 SerializableSupplier
问题描述
在 PrimeFaces 8.0 中,DefaultStreamedContent
不能像这样初始化,new DefaultStreamedContent(inputStream, contentType, name)
因为它已被弃用,而是你应该使用DefaultStreamedContent.builder()
.
尽管在8.0.0 之前的版本中,.stream()
它要求 aSerializableSupplier<InputStream>
而不是InputStream
like。
DefaultStreamedContent.builder().contentType(contentType).name(name).stream(is).build();
^^
如何将 a 转换InputStream
为 a SerializableSupplier
?
解决方案
一切都在迁移指南中:https ://github.com/primefaces/primefaces/wiki/Migration-Guide 。
一般来说,以下将起作用:
DefaultStreamedContent.builder().contentType(contentType).name(name).stream(() -> is).build();
但改变背后的想法是不同的。
如果您使用 RequestScoped bean 来构建 StreamedContent,那么您的 bean 以及 StreamedContent 将被创建两次:
- 渲染视图时
- 流式传输资源时(这是一个新的浏览器请求!)
在这种情况下,您的is
遗嘱可能会创建 2 次。大多数情况下,这会导致 1 次无用的 IO 访问或 DB 调用。
要只创建is
一次,您应该通过供应商 lambda 延迟初始化它:
DefaultStreamedContent.builder().contentType(contentType).name(name).stream(() -> new FileInputStream(....)).build();
推荐阅读
- java - 通过多个可选参数过滤 api
- javascript - 如何在数组的开头移动所有零项?
- javascript - 从外部组件单击按钮时在一个组件中打开特定选项卡
- java - 在recyclerview中发布关于activityresult的问题
- html - 如何在 div class='App' 反应之前添加多个静态 html 元素?
- spring-amqp - Spring AMQP 中的预取与批处理
- raku - Raku 在编译时执行哪些类型检查?将来可能会改变吗?
- python - _Scrape_ 块引用 bs4 后的文本
- python-sphinx - 在 Sphinx+Doxygen 文档中显示文件夹结构
- python - 使用 Python(modbus 连接)向 Siemens Logo 8 发送位