在咱们的程序开发当中,常常会用到java.sql.Blob、byte[]、InputStream之间的相互转换,但在JDK的API当中,又没有直接给咱们提供可用的API,下面的程序片断主要就是实现它们之间互换的util.java
1、byte[]=>Blobsql
咱们能够经过Hibernate提供的表态方法来实现如:数组
org.hibernate.Hibernate.Hibernate.createBlob(new byte[1024]);hibernate
2、Blob=>byte[]图片
目前没有找到好一点的API提供,因此只能自已来实现。示例以下:开发
/**get
* 把Blob类型转换为byte数组类型input
* @param blobit
* @returnio
*/
private byte[] blobToBytes(Blob blob) {
BufferedInputStream is = null;
try {
is = new BufferedInputStream(blob.getBinaryStream());
byte[] bytes = new byte[(int) blob.length()];
int len = bytes.length;
int offset = 0;
int read = 0;
while (offset < len && (read = is.read(bytes, offset, len - offset)) >= 0) {
offset += read;
}
return bytes;
} catch (Exception e) {
return null;
} finally {
try {
is.close();
is = null;
} catch (IOException e) {
return null;
}
}
}
3、InputStream=>byte[]
private byte[] InputStreamToByte(InputStream is) throws IOException {
ByteArrayOutputStream bytestream = new ByteArrayOutputStream();
int ch;
while ((ch = is.read()) != -1) {
bytestream.write(ch);
}
byte imgdata[] = bytestream.toByteArray();
bytestream.close();
return imgdata;
}
4、byte[]=> InputStream
byte[]到inputStream之间的转换很简单:InputStream is = new ByteArrayInputStream(new byte[1024]);
5、InputStream => Blob
可经过Hibernate提供的API:Hibernate.createBlob(new FileInputStream(" 能够为图片/文件等路径 "));
6、Blob => InputStream
Blog转流,可经过提供的API直接调用:new Blob().getBinaryStream();
以上片断可做为读者参考。