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

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

原理同上

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

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值