数据库的显示乱码

在mysql4.1.0中,varchar类型,text类型就会出现中文乱码,对于varchar类型把它设为binary属性就
  可以解决中文问题,对于text类型就要用一个编码转换类来处理,实现如下:
 

 public class Convert {
  /** 把ISO-8859-1码转换成GB2312
  */
  public static String ISOtoGB(String iso){
  String gb;
  try{
  if(iso.equals("") || iso == null){
  return "";
  }
  else{
  iso = iso.trim();
  gb = new String(iso.getBytes("ISO-8859-1"),"GB2312");
  return gb;
  }
  }
  catch(Exception e){
  System.err.print("编码转换错误:"+e.getMessage());
  return "";
  }
  }
  }

 

  把它编译成class,就可以调用Convert类的静态方法ISOtoGB()来转换编码。
  
  总结:
  1. 在jsp中<%@ page contentType="text/html; charset=A" %>如果指定了,那么在改jsp中所有构造
  的String(不是引用),如果没有指定编码,那么这些String的编码是A的。
   从request的得到的String如果没有指定request的编码的话,他是iso-8859-1的
   从别的地方得到的String是使用原来初始的编码的,比如从数据库得到String,如果数据库的编码
  是B,那么该String的编码是B而不是A的,也不是系统默认的。
   此时,如果要输出的String的编码不是A,那么,很可能显示乱码的,所以首先要将String正确转化
  为编码A的String,然后输出。
  2. 在jsp中<%@ page contentType="text/html; charset=A" %>没有指定,那么相当于指定了<%@
  page contentType="text/html; charset=ISO-8859-1" %>
  3. Servelte中如果执行了像 response.setContentType("text/html;charset=A");说明将response的
  字符输出流编码设置为A,所有要输出的String的编码要转化为A的,否则会得到乱码的。
   Servelet中从request得到的String的编码和jsp中一样的,但是在servlet java文件中构造的
  String是使用的系统默认的编码的。在servelt中从外部得到的String 是使用原来的编码的,比如从编
  码为B的数据库得到的数据是编码为B的,不是A,也不是系统默认的编码。


之前所写,迁移至此

原文链接:http://user.qzone.qq.com/372806800/blog/1336199097

posted @ 2016-12-22 11:36  风来风往风伤(TiAmo)  阅读(253)  评论(0编辑  收藏  举报