不同系统之间的调用产生的中文乱码问题
1、问题描述
工作中不免会遇到各种中文乱码问题,比如在系统调用中,由于各系统字符编码可能不太一样,比如A系统代码文件使用的是GBK编码,B系统代码文件使用UTF-8编码,这样如果A系统调用B系统,在代码运行的过程中,就会出现中文乱码问题。
2、解决办法
- 可以使用String类转换字符串编码
String remark = "xxx"; // gbk格式字符串
String res = new String(remark.getBytes("gbk"), "utf-8"); // utf-8编码格式字符串
- 使用URLEncoder编码
URLEncoder和URLDecoder是Java中用于对URL进行编码和解码的工具类。可以对URL中的特殊字符进行编码或者解码操作,保证数据在传输或逻辑处理过程中不会出现错误,可以很好的解决URL中传输中文字符的问题。URLEncoder用于对URL进行编码,将URL中的特殊字符转换为%加上对应的ASCII码值。URLDecoder用于对URL进行解码,将编码的特殊字符转换回原始字符。
在A系统调用B系统前,使用URLEncoder编码,B系统接收到参数后,使用URLDecoder解码,这样就可以解决乱码问题了。
import java.net.URLEncoder;
import java.net.URLDecoder;
String encode = URLEncoder.encode(remark, "utf-8");
String decode = URLDecoder.decode(encode, "utf-8");