JSP中若要显示出中文,必须得在JSP页面或servlet中设置中文字符编码GB2312或GBK,
JSP中若用ISO-8859-1编码是不能正常显示中文的.
mysql中若要进行中文存储,中文字符必须是ISO-5589-1(或latin1),用GB2312是不能正常存储中文的 ,
通过上面的分析,我们得出
JSP:GB2312
mysql:ISO-8859-1
显示中文.
所以,JSP中的所有的字符,String对象,在插入MYSQL前进行
public String str_GB2312_ISO(String str)//插数据的时候
{
try
{
str = new String(str.getBytes("gb2312"), "ISO-8859-1");
}
catch (UnsupportedEncodingException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
return str;
}
用GB2312解码字符串为byte[],再用ISO-8859-1编码为String,之后再插入数据库
MYSQL中的所有字符串在取出之后,显示在JSP上之前,进行
public String str_ISO_GB2312(String str)//取数据的时候//运用在SImple Class Bean上,比较方便,不用每次都用这 个函数
{
try
{
str = new String(str.getBytes("ISO-8859-1"), "gb2312");
}
catch (UnsupportedEncodingException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
return str;
}
原理同上
乱码问题其实就是一个字符转换问题