我的数据库表中有一个blob列,必须byte[]
在Java程序中将其用作映射,并使用此数据将其转换为InputStream
或OutputStream
。但是我不知道这样做的时候内部会发生什么。有人能简要解释一下我进行此转换时发生了什么吗?
我的数据库表中有一个blob列,必须byte[]
在Java程序中将其用作映射,并使用此数据将其转换为InputStream
或OutputStream
。但是我不知道这样做的时候内部会发生什么。有人能简要解释一下我进行此转换时发生了什么吗?
Answers:
您可以按以下方式创建和使用字节数组I / O流:
byte[] source = ...;
ByteArrayInputStream bis = new ByteArrayInputStream(source);
// read bytes from bis ...
ByteArrayOutputStream bos = new ByteArrayOutputStream();
// write bytes to bos ...
byte[] sink = bos.toByteArray();
假设您使用的是实现标准JDBC Blob接口的JDBC驱动程序(并非全部这样做),则还可以使用和方法1将a InputStream
或连接OutputStream
到blob ,并且还可以直接获取和设置字节。getBinaryStream
setBinaryStream
(通常,您应该采取适当的步骤来处理所有异常并关闭流。但是,在上面的示例中,关闭bis
和bos
是不必要的,因为它们与任何外部资源都没有关联;例如,文件描述符,套接字,数据库连接。)
1-该setBinaryStream
方法实际上是一种吸气剂。去搞清楚。
我假设您的意思是'use'表示读取,但是我将为读取情况解释的内容基本上可以与写入情况相反。
所以你最后得到一个byte []。这可以表示可能需要特殊类型转换(字符,加密等)的任何类型的数据。假设您要将此数据原样写入文件。
首先,您可以创建一个ByteArrayInputStream,它基本上是一种将字节按顺序提供给某些对象的机制。
那么您可以为要创建的文件创建FileOutputStream。对于不同的数据源和目标,有许多类型的InputStreams和OutputStreams。
最后,您将InputStream写入OutputStream。在这种情况下,字节数组将按顺序发送到FileOutputStream进行写入。为此,我建议使用IOUtils
byte[] bytes = ...;//
ByteArrayInputStream in = new ByteArrayInputStream(bytes);
FileOutputStream out = new FileOutputStream(new File(...));
IOUtils.copy(in, out);
IOUtils.closeQuietly(in);
IOUtils.closeQuietly(out);
反过来
FileInputStream in = new FileInputStream(new File(...));
ByteArrayOutputStream out = new ByteArrayOutputStream();
IOUtils.copy(in, out);
IOUtils.closeQuietly(in);
IOUtils.closeQuietly(out);
byte[] bytes = out.toByteArray();
如果使用上述代码段,则需要处理异常,我建议您在finally块中执行“关闭”操作。
我们可以使用ByteArrayInputStream将byte []数组转换为输入流
String str = "Welcome to awesome Java World";
byte[] content = str.getBytes();
int size = content.length;
InputStream is = null;
byte[] b = new byte[size];
is = new ByteArrayInputStream(content);
有关完整示例,请在此处查看http://www.onlinecodegeek.com/2015/09/how-to-convert-byte-into-inputstream.html
byte[] data = dbEntity.getBlobData();
response.getOutputStream().write();
我认为这样做会更好,因为您在响应对象中已经有一个OutputStream了。无需创建新的OutputStream。