java中字符乱码转化的问题

现在有个系统A向系统B发送报文。系统A发送报文时的编码格式为GBK,而系统B接收报文时使用UTF-8解析。
当系统A向B发送如下报文时: "aaa你好",系统B解析时其中中文会乱码,可能接收到的报文为:"aaa啔屶",现在不能够要求系统A改变发送报文时使用的编码格式。
最好能通过转化的方式将系统B接收到的乱码转回为正常的GBK格式,有这样的方法吗?

ps:系统A通过http请求到系统B,系统B通过request 获取到系统A传过来的报文。
系统B是个java web工程,接收报文的serverlet使用了过滤器 encoding ,值为UTF-8.
并且s.getBytes() 获取到的值和 s.getBytes("UTF-8")是一样的。

new String(s.getBytes("UTF-8"),"GBK")结果还是乱码的。

如果B接受编码方式也不能更改为和A一致,那么举个例子
A GBK,B UTF-8
B获取的内容乱码,
String s=request.getParameter("字段名");
这里s会乱码,可以做如下转换
byte[] bytes=s.getBytes(" B当前的编码格式");
String s=new String(bytes,"A的编码方式");
这个时候s就正常了
温馨提示:答案为网友推荐,仅供参考
第1个回答  2015-05-04
系统B通过request 获取到系统A传过来的报文 在后台用JAVA转码一下啊
例如 new String(str.getBytes("gb2312"), "utf8"); 这个就是字符串先以gb2312解码,再用utf8编码
第2个回答  2015-05-04
用 new String(str.getBytes(),"utf-8")
第3个回答  2015-05-04
首先如果你确认 A 发过来的是GBK那么调用的时候就把这个转下.
如果不确定A发过来的是GBK 那就检测byte 看看是什么编码(具体检测方法可以百度下判断utf-8)