在我们的程序开发当中,经常会用到java.sql.Blob、byte[]、InputStream之间的相互转换,但在JDK的API当中,又没有直接给我们提供可用的API,下面的程序片段主要就是实现它们之间互换的util.
一、byte[]=>Blob
我们可以通过Hibernate提供的表态方法来实现如:
org.hibernate.Hibernate.Hibernate.createBlob(new byte[1024]);
二、Blob=>byte[]
目前没有找到好一点的API提供,所以只能自已来实现。示例如下:
/**
* 把Blob类型转换为byte数组类型
* @param blob
* @return
*/
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;
}
}
}
三、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;
}
四、byte[] => InputStream
byte[]到inputStream之间的转换很简单:InputStream is = new ByteArrayInputStream(new byte[1024]);
五、InputStream => Blob
可通过Hibernate提供的API:Hibernate.createBlob(new FileInputStream(" 可以为图片/文件等路径 "));
六、Blob => InputStream
Blog转流,可通过提供的API直接调用:new Blob().getBinaryStream();
以上片段可作为读者参考。
相关推荐
Blob、InputStream、byte 互转
ORACLE数据库中主要字段类型的读写例子(包括:Long、Raw、Blob) (2).docxORACLE数据库中主要字段类型的读写例子(包括:Long、Raw、Blob) (2).docxORACLE数据库中主要字段类型的读写例子(包括:Long、Raw、Blob) (2)....
ORACLE数据库中主要字段类型的读写例子(包括:Long、Raw、Blob) (2).pdfORACLE数据库中主要字段类型的读写例子(包括:Long、Raw、Blob) (2).pdfORACLE数据库中主要字段类型的读写例子(包括:Long、Raw、Blob) (2)....
资源来自pypi官网。 资源全名:textblob-nl-0.0.1.tar.gz
[java]将Byte存入blob.rar
oracle_BLOB字段上传附件步骤.doc,oracle_BLOB字段上传附件步骤.doc
资源来自pypi官网。 资源全名:textblob-0.13.0.tar.gz
资源来自pypi官网。 资源全名:js.javascript_canvas_to_blob-2.0.5.tar.gz
java中sqllite数据库blob数据类型的存取.docx
基于Linux的BLOB文件系统的设计.pdf
JAVA中SQLlite数据库BLOB数据类型的存取.docx
基于Linux的BLOB文件系统的实现.pdf
最近开发遇到blob类型转换为String,一时犯难。所以总结了一段代码与之分享。亲测
资源分类:Python库 所属语言:Python 资源全名:textblob-fr-0.1.0.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059
在C中存取Oracle数据库表中BLOB数据的方法研究.pdf
基于.NET的Oracle BLOB数据高效存取方法.pdf
使用JAVA读取ORACLE_BLOB字段实现上传下载.doc
在Oracle数据表中存取BLOB数据的方法研究.pdf
利用Java语言实现PB对Oracle中Blob类型的动态操作.pdf
此文件专门为微信小程序使用,使用教程https://blog.csdn.net/weixin_42594068/article/details/116521561 crypto模块的目的是为了提供通用的加密和哈希算法。用纯JavaScript代码实现这些功能不是不可能,但速度会...