在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