Java中将字节数组转为Blob对象(不连接数据库的实用技巧)

 📄 摘要

在某些业务场景中,我们可能需要将图片、PDF 等二进制内容临时封装为 BLOB 对象以便后续传输或格式兼容操作,但此时我们并不打算连接数据库,或者只是单纯为了和某些接口或类进行交互。本文将介绍如何使用 javax.sql.rowset.serial.SerialBlob 类,轻松实现字节数组向 BLOB 对象的转换,无需依赖数据库连接。


🧠 为什么不直接用 oracle.sql.BLOB?

oracle.sql.BLOB 是专用于 Oracle JDBC 驱动的 BLOB 类型,使用时必须依赖数据库连接(Connection)。但在很多情况下,我们只是希望:

  • 暂存一个 BLOB 对象;

  • 与某些只接受 java.sql.Blob 类型的方法兼容;

  • 不想引入冗余数据库连接。

这时候,SerialBlob 就是我们最好的选择。


✅ SerialBlob 简介

SerialBlob 是 Java 提供的一个序列化 BLOB 实现,属于 javax.sql.rowset.serial 包。

它实现了 java.sql.Blob 接口,可用于程序中独立操作 BLOB 对象,不依赖任何数据库连接。


🔨 示例代码:Base64字符串转BLOB对象

import javax.sql.rowset.serial.SerialBlob;
import java.sql.Blob;
import java.util.Base64;

public class BlobExample {

    public static Blob base64ToBlob(String base64Str) throws Exception {
        // 解码 Base64 为字节数组
        byte[] imageBytes = Base64.getDecoder().decode(base64Str);

        // 将字节数组转为 BLOB 对象
        return new SerialBlob(imageBytes);
    }

    public static void main(String[] args) throws Exception {
        String schoolFaceBase64 = "iVBORw0KGgoAAAANSUhEUgAAA..."; // 示例Base64字符串

        Blob blob = base64ToBlob(schoolFaceBase64);

        // 输出 BLOB 的长度
        System.out.println("BLOB size = " + blob.length());
    }
}

📌 适用场景

  • ✅ 上传图片或文件后,封装为 BLOB 后传递给第三方 SDK 或存储类;

  • ✅ 单元测试中模拟 Blob 数据;

  • ✅ 不依赖数据库就需要处理 BLOB 类型的通用方法;

  • ✅ 与一些只接受 java.sql.Blob 接口的工具类/方法兼容。


💡 注意事项

  • SerialBlob 构造函数会复制字节数组,因此对原数组的更改不会影响 BLOB;

  • 不是所有 JDBC 驱动都能识别 SerialBlob,仅用于 Java 内存处理或与兼容接口配合使用;

  • 若最终要存入 Oracle 数据库,请使用 oracle.sql.BLOB,并通过 JDBC Connection 写入。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jamie Chyi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值