我有一个Java存储过程,该过程使用Resultset对象从表中获取记录并创建CS Vfile。

BLOB retBLOB = BLOB.createTemporary(conn, true, BLOB.DURATION_SESSION);
retBLOB.open(BLOB.MODE_READWRITE);
OutputStream bOut = retBLOB.setBinaryStream(0L);

ZipOutputStream zipOut = new ZipOutputStream(bOut);
PrintStream out = new PrintStream(zipOut,false,"UTF-8");
out.write('\ufeff');
out.flush();

zipOut.putNextEntry(new ZipEntry("filename.csv"));
while (rs.next()){
    out.print("\"" + rs.getString(i) + "\"");
    out.print(",");
}
out.flush();

zipOut.closeEntry();
zipOut.close();
retBLOB.close();

return retBLOB;

但是,生成的CSV文件未显示正确的德语字符。 Oracle数据库还具有UTF8的NLS_CHARACTERSET值。

请提出建议。

最佳答案

要以UTF-8编写BOM,您需要PrintStream.print(),而不是PrintStream.write()

另外,如果您想在csv文件中包含BOM,我想您需要在putNextEntry()之后打印BOM。

关于java - 如何在Java中添加UTF-8 BOM?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/4389005/

10-13 03:25