Blob、InputStream、byte[] 互转

在我们的程序开发当中,经常会用到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();

以上片段可作为读者参考。

时间: 2024-07-29 07:05:33

Blob、InputStream、byte[] 互转的相关文章

字符串string和内存流MemoryStream及比特数组byte[]互转

原文:字符串string和内存流MemoryStream及比特数组byte[]互转     字符串string和内存流MemoryStream及比特数组byte[]互转比较 定义string变量为str,内存流变量为ms,比特数组为bt 1.字符串转比特数组(1)byte[] bt=System.Text.Encoding.Default.GetBytes("字符串");(2)byte[] bt=Convert.FromBase64String("字符串"); 2.

Java 类型相互转换byte[]类型,Blob类型详细介绍_java

在我们的程序开发当中,经常会用到java.sql.Blob.byte[].InputStream之间的相互转换,但在JDK的API当中,又没有直接给我们提供可用的API,下面的程序片段主要就是实现它们之间互换的util. 一.byte[]=>Blob 我们可以通过Hibernate提供的表态方法来实现如: org.hibernate.Hibernate.Hibernate.createBlob(new byte[1024]); 二.Blob=>byte[] 目前没有找到好一点的API提供,所以

在Java中使用Oracle blob

oracle Oracle中的lob (Large Object)可以存储非常大的数据(可能是4GB),这样就可以通过将文件或其它任何对象序列化成字节输出流(OutputStream)后写入数据库,之后使用字节输入流(InputStream)将数据读出然后反序列化为原始文件或对象.操作时需要使用oracle的JDBC包,它扩展了sun的JDBC包中的Blob对象.同时需要注意一些细节.下面的代码演示如何使用blob(实例中需要Oracle的JDBC包). import oracle.jdbc.O

java-Oracle读取二进制BLOB类型数据出现乱码

问题描述 Oracle读取二进制BLOB类型数据出现乱码 JAVA中,读取Oracle中二进制BLOB类型数据,出现乱码.. 如果BLOB是文本类型存储的就不会存在乱码 BLOB blob = (oracle.sql.BLOB)rs.getBlob(""ys1""); try{ FileOutputStream outStream = new FileOutputStream(""c:/oracleback1.txt"");

jsp 输出图片 blob.getBytes()问题

问题描述 jsp 输出图片 blob.getBytes()问题 response.setContentType("image/jpeg"); String userName = request.getParameter("userName"); Class.forName("oracle.jdbc.driver.OracleDriver"); String url = "jdbc:oracle:thin:@127.0.0.1:1521:

java读写oracle的blob字段示例_java

复制代码 代码如下: package com.wanmei.meishu; import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.FileReader;import java.io.InputStream;import java.io.OutputStream;import java.sql.Connection;import java.sql.DriverManager;import java

解析使用jdbc,hibernate处理clob/blob字段的详解_java

(1)不同数据库中对应clob,blob的类型:mysql中 : clob对应text  blob对应blobdb2/oracle中 clob对应clob blob对应blob (2)domain中对应类型:clob 对应 String   blob 对应 byte[]clob 对庆 java.sql.Clob blob 对应 java.sql.Blob (3)hibernate配置文件中对应类型:clob > clob   blob > binay 也可以直接使用数据库提供类型,例如:ora

byte 字节

byte 一个byte表示8位,第一个位是符号位,所以正数最大为0111 1111,也就是数字127,  负数最大为1111 1111,也就是数字-128. String与byte互转 Charset java.nio.charset.Charset.forName(String charsetName) 由这个静态方法得到Charset.例如Charset.forName("utf-8"); byte[] java.lang.String.getBytes(Charset chars

关于在ORACLE下开发JAVA的几个问题

oracle|问题 我本来不再想写一些类似教程的文章,因为既然叫教程就要能历经历史的考验,而对于我这种菜鸟级的程序设计者来说仅喜欢随心所欲地交流一些自己的经验.可以不成方法,无关条理地想到哪说到哪.但是有些问题我又不能不出来说明白,因为目前网上的很多"教程"都在把初学者引向错误,有些是作者个人理解的错误,有些作者自己从来没有做过开发却能写出一篇软件开发的文章.他们只会做TRANSLATE,COPY,CUT这些操作,最简单的例子就是sun的JDK开发文档中到目前为止介绍大对象(文件)存储