数据库的显示乱码

发布时间:2017-4-29 6:04:50 编辑:www.fx114.net 分享查询网我要评论
本篇文章主要介绍了"数据库的显示乱码 ",主要涉及到数据库的显示乱码 方面的内容,对于数据库的显示乱码 感兴趣的同学可以参考一下。

在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


上一篇:看完SQL Server 2014 Q/A答疑集锦:想不升级都难!
下一篇:工作与生活如何平衡?

相关文章

相关评论

本站评论功能暂时取消,后续此功能例行通知。

一、不得利用本站危害国家安全、泄露国家秘密,不得侵犯国家社会集体的和公民的合法权益,不得利用本站制作、复制和传播不法有害信息!

二、互相尊重,对自己的言论和行为负责。

好贷网好贷款