图片组件是否支持设置base64的字符串

请问图片组件能否在后台用代码设置base64的字符串来显示图片内容?

我感觉这样就行,你试下:

byte[] imgBytes = Base64.getDecoder().decode(yourImageString);
image.setSource(StreamResource.class).setStreamSupplier(() -> new ByteArrayInputStream(imgBytes));

这样是可以,不过多了一次解码。能否实现H5里的src=“data:image/jpeg;base64,”这样的方式呢?
试了下没成功

this.image.setSource(UrlResource.class)
                                    .setUrl(new URL("data:image/" + kind +";base64,"+base64));

嗯。已经通过 InputStream 支持二进制数据了,就不支持后面这种了。解码是不可避免的。而且 CUBA 都是后台程序,解码都是在后台做,这两种区别无非是解码的代码是自己写还是框架实现。

不对吧,这种方式是客户端的浏览器解码,不是后台解码。

不是的。Vaadin 的基本思想就是在服务端进行计算和创建 UI 元素,在浏览器渲染需要的 html/css/js 都是在服务端创建好之后再发送给浏览器的。

我知道啊,但是你后台传给页面的是直接的BASE64的字符串啊,不需要做解码了。

查了下,CUBA 是不支持的。但是 Vaadin 支持:

CubaImage unwrap = image.unwrap(CubaImage.class);
unwrap.setSource(new ExternalResource(""));
1 个赞

谢谢。nice!