由于在使用ORACLE和iReport,但是iReport里面不支持CLOB,我又写了个类,把CLOB字段指定为InputStream,然后通过转换变成String。
英文是可以的,但是中文就不行了,以下是部分代码:
public String inputStream2String (InputStream in) throws IOException {
StringBuffer out = new StringBuffer();
byte[] b = new byte[4096];
for (int n; (n = in.read(b)) != -1;) {
out.append(new String(b, 0, n));
}
return out.toString();
}
里面加这么一句:
String clob = new String(out.toString().getBytes("iso8859-1"),"gb2312");
return clob;
返回的还是乱码。
怎么做下编码格式的转换?分不多,但是很急,希望大家能帮忙。
[b]问题补充:[/b]
to lovewhzlq:
不行,还是乱码。
[b]问题补充:[/b]
to layer555:
谢谢,有变化,但还是乱码。
是不是InputStream to byte 的过程也要转下?
[b]问题补充:[/b]
to ywbanm:
是GB2312,IR是一种报表软件,似乎只支持UTF-8,于是我把项目编码改成UTF-8,代码里也写成UTF-8,一样还是乱码。
谢谢 :oops:
[b]问题补充:[/b]
最后还是使用了Object的方式解决了乱码的问题,谢谢大家。
从你贴的代码看,是在从ORACLE读出的时候就乱码了,和iReport似乎没有关系(不知道你的数据是如何入库的)。
所以你现在能确定,
1,数据入到ORACLE是正常的么?
2,GB2312是ORACLE的编码还是你开发环境的?
3,out.toString().getBytes("JVM编码"),"ORACLE的编码"
4,‘把CLOB字段指定为InputStream’,你确定这个InputStream打开的编码方式正确么?
你DB的Encoding是什么?
你开发环境的Encoding又是什么?
为什么不统一呢。都用UTF8不就什么事都没有了么
用InputStreamReader包装一下InputStream
[code="java"]
public String inputStream2String (InputStream in , String encoding) throws IOException {
StringBuffer out = new StringBuffer();
InputStreamReader inread = new InputStreamReader(in,encoding);
char[] b = new char[4096];
for (int n; (n = inread.read(b)) != -1;) {
out.append(new String(b, 0, n));
}
return out.toString();
}
[/code]
String clob = new String(out.toString().getBytes(),"gb2312"); 把第一个编码去掉试试
你先把自己环境用的编码方式搞清楚,要不大家帮你一块猜也没用
我遇到一个奇怪的问题,怎么转都乱码,最后是因为gzip的问题,在这里解决了![url]http://www.sojson.com/blog/227.html[/url]