• 数据库的显示乱码


    在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

  • 相关阅读:
    框架代码 2
    框架代码 2
    个人资料  代码
    个人资料  代码
    XHTML表单
    框架代码 1
    计算机科学与技术学习反思录(转载)
    写在Blog点击数超过50000之后...
    小笨霖英语笔记本(6)水电
    SUN服务器及Solaris Serial Console常见设置问题
  • 原文地址:https://www.cnblogs.com/amwuau/p/6210512.html
Copyright © 2020-2023  润新知