我想将二进制数据(例如PDF)分成我的Oracle数据库的BLOB。 起初我将PDF放入FileInputStream并创建了一个byte-array.Here是代码:
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 ......但是那个dowsnt很重要),它连接到某个数据库并将所有内容存储到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,存储byte []并将此byte []放到数据库的BLOB中。 我需要做什么,以正确的方式在我的数据库中存储PDF,以便之后我可以正确解析JDBC连接器创建的XML文件?
答案 0 :(得分:2)
您可以使用JAXB DatatypeConverter类轻松地将数据转换为base64,而不需要任何外部依赖项:
byte[] arr = YOUR_BINARY_ARRAY;
String result = javax.xml.bind.DatatypeConverter.printBase64Binary(arr);
您只需将此代码添加到方法的末尾,并将其返回类型更改为String。
答案 1 :(得分:0)
您可以尝试使用Apache Commons首先将字节转换为basse64,例如:
import org.apache.commons.codec.binary.Base64;
import java.util.Arrays;
public class Base64Encode {
public static void main(String[] args) {
String hello = "Hello World";
byte[] encoded = Base64.encodeBase64(hello.getBytes());
System.out.println(Arrays.toString(encoded));
String encodedString = new String(encoded);
System.out.println(hello + " = " + encodedString);
}
}