数据库的显示乱码

在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 @   风来风往风伤(TiAmo)  阅读(256)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
点击右上角即可分享
微信分享提示