我想将二进制数据(例如 PDF)放入我的 Oracle 数据库的 BLOB 中。
起初,我将 PDF 放入 FileInputStream 并创建了一个字节数组。这是代码:

public static byte[] createByteArray(File pCurrentFolder, String pNameOfBinaryFile)
    {

        String pathToBinaryData = pCurrentFolder.getAbsolutePath()+"/"+pNameOfBinaryFile;

        File file = new File(pathToBinaryData);
        if (!file.exists())
        {
            System.out.println(pNameOfBinaryFile+" could not be found in folder "+pCurrentFolder.getName());
            return null;
        }

        FileInputStream fin = null;
        try {
            fin = new FileInputStream(file);
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        }

        byte fileContent[] = new byte[(int) file.length()];

        try {
            fin.read(fileContent);
        } catch (IOException e) {
            e.printStackTrace();
        }

        return fileContent;
    }

我通过 MyBatis 将这个(字节数组)发送到数据库并且它起作用了,所以我的 BLOB 中有 PDF,我也可以从我的数据库中读取 PDF。
但现在我面临以下问题:
我有一个用于我的搜索引擎的 JDBC 连接器(FAST ESP...但是这很重要)它连接到某个数据库并将所有内容存储到一个 xml 文件中。在这个 xml 文件中有一个名为“data”的元素,它在其 CDATA 字段中包含二进制数据。

当我想解析这个 xml 时,Java 告诉我:
The content of elements must consist of well-formed character data or markup.

使用一些 PDF 我可以工作,但有些则不行。所以我认为问题是,我以错误的方式将它们存储在数据库中。

有关更多信息,我会尊重我之前提出的另一个与此类似的问题。

Java: skip binary data in xml file while parsing

有人告诉我应该用 base64 编码我的 PDF(或任何二进制文件)。所以这意味着,我不只是将我的 PDF 放入 FileInputStream,存储字节 [] 并将这个字节 [] 放入我的数据库 BLOB 中。
我该怎么做才能以正确的方式将 PDF 存储在我的数据库中,以便之后我可以正确解析 JDBC 连接器创建的 XML 文件?

最佳答案

您可以使用 JAXB DatatypeConverter 类轻松地将数据转换为 base64,而无需任何外部依赖项:

byte[] arr = YOUR_BINARY_ARRAY;
String result = javax.xml.bind.DatatypeConverter.printBase64Binary(arr);

您可以简单地将此代码添加到方法的末尾并将其返回类型更改为字符串。

关于java - 将PDF转换为Base64并将数据存储到数据库的BLOB,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11742179/

10-13 04:23
查看更多