JSP与mysql之间的中文乱码问题的解答(绝对有效)

来源:互联网 发布:mac ppt设置背景音乐 编辑:程序博客网 时间:2024/05/21 17:53

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;
 }

原理同上

乱码问题其实就是一个字符转换问题