已完成的项目中,全部使用utf-8的编码,在开始的服务器上跑的好好的,现在换了个服务器后,数据库中的原始数据正常,但是添加数据的时候中文就是乱码。项目用的是struts+jsp+javabean  . 有些地方直接取得中文后必须要显示将起编码改成gbk就显示正常,但是同样的写法在其他地方却不行。
   郁闷得很,不知道怎么弄了,期待路过的朋友帮忙解决....

解决方案 »

  1.   

      数据库是sql server 2000 ,tomcat 5.5 配置的项目
      

  2.   

    tomcat 5.5 配置的项目
    看看tomcat中的conf文件夹下的server.xml配置中的字符编码是不是统一了。<Connector port="端口号" protocol="HTTP/1.1" 
                   maxThreads="150" connectionTimeout="20000" 
                   redirectPort="8443" URIEnconding="utf-8"/>
      

  3.   

    在乱码方面 最好是设置个过滤器 来拦截post过来的数据,然后在server.xml中修改下URIEncoding="UTF-8" 解决get过来的数据 基本上就OK了 还有就是在脚本之间传递的时候 要对汉字用encodeURI()进行编码 我们的项目就是这样搞的 不存在中文乱码问题
      

  4.   

    建议使用过滤器解决 http://www.javaeye.com/topic/198556
      

  5.   

    首先就是换了的服务器上重装mysql的时候,mysql的默认字符集是不是utf-8,我觉得只要这一路全部设成utf-8了应该没问题,再就是楼上说的服务器的问题,楼主有过滤器的话应该不用考虑页面
      

  6.   

    tomact5的post和get的编码方式不一样,是不是你用get的地方就出错啊,在tomcat的server.xml中的connector中添加URLEncoding=“utf-8” 试一下
      

  7.   

    1.过滤器
    2.修改sever.xml 配置URIEcoding=""
    3.Jsp 的编码统一一般就没有问题了
      

  8.   

    应该是tomcat的配置文件的编码设置问题。
      

  9.   

    good~~楼主是强人啊 ~~~~哈哈
      

  10.   

    怎么能是数据库问题吗,既然原先的tomcat好用,为什么要换啊。。换了的话,新的服务器的server配置与原来的一样吗?特别是设置编码那块。14楼总结的已经是常见乱码问题的常用解决办法了。再就是 你可以在传数据时把数据转为ISO-8859-1,传到Action时再转为utf-8.
      

  11.   

    一、JSP页面显示乱码 下面的显示页面(display.jsp)就出现乱码: 对不同的WEB服务器和不同的JDK版本,处理结果就不一样。原因:服务器使用的编码方式不同和浏览器 
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 对不同的字符显示结果不同而导致的。解决办法:在JSP页面中指定编码方式(gb2312),即在页面的第一 行加上: <%@ page contentType="text/html; charset=gb2312"%> 就可以消除乱码了。完整页面如下: 
    二、表单提交中文时出现乱码 
    <%@ page contentType="text/html; charset=gb2312"%> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 如果提交英文字符能正确显示,如果提交中文时就会出现乱码。原因:浏览器默认使用UTF -8编码方式来发送请求,而UTF- 8和GB2312编码方式表示字符时不一样,这样就出现了不能识别字符。 解决办法:通过request.seCharacterEncoding ("gb2312")对请求进行统一编码,就实现了中文的正常 显示。 
    三、数据库连接出现乱码 只要涉及中文的地方全部是乱码,解决办法:在数据库的数据库URL中加上 useUnicode=true&characterEncoding=GBK 就OK了。 四、数据库的显示乱码 在mysql4.1.0中,varchar类型,text类型就会出现中文乱码,对于varchar类型把它设为binary属性就 可以解决中文问题,对于text类型就要用一个编码转换类来处理,实现如下: 
    把它编译成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,也不是系统默认的编码。 JSP中文乱码问题解决方法小结   在使用JSP的过程中,最使人头疼的一个问题就是中文乱码问题,以下是我在软件开发中遇到的乱 码问题以及解决方法。 1、JSP页面乱码   这种乱码的原因是应为没有在页面里指定使用的字符集编码,解决方法:只要在页面开始地方用下 面代码指定字符集编码即可, 2、数据库乱码   这种乱码会使你插入数据库的中文变成乱码,或者读出显示时也是乱码,解决方法如下:   在数据库连接字符串中加入编码字符集 
    String Url="jdbc:mysql://localhost/digitgulf? user=root&password=root&useUnicode=true&characterEncoding=GB2312";   并在页面中使用如下代码:   response.setContentType("text/html;charset=gb2312");   request.setCharacterEncoding("gb2312"); 3、中文作为参数传递乱码   当我们把一段中文字符作为参数传递个另一页面时,也会出现乱码情况,解决方法如下:   在参数传递时对参数编码,比如 
    RearshRes.jsp?keywords=" + java.net.URLEncoder.encode(keywords) 
      然后在接收参数页面使用如下语句接收 
     keywords=new String(request.getParameter("keywords").getBytes("8859_1")); 
    4、JSP页面乱码加这句 
    <%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="err.jsp" %> JSP的request 默认为ISO8859_1,所以在处理中文的时候, 要显示中文的话,必须转成GBK的,如下 String str=new String(request.getParameter("name").getBytes("ISO8859-1"),"GBK"); out.println(str); 这样就可以显示中文了 1.插入中文: String sql2="INSERT INTO test (name) VALUES('"+request.getParameter("name")+"')"; stmt.executeUpdate(sql2); 不用编码就可以插入了 2.显示插入的中文: 因为存入的是latin,所以显示的时候就要GBK一下 String x=new String((rs.getString("title")).getBytes("ISO8859_1"),"GBK"); out.println(x); 3.设定存储编码: 当然在MySQL为latin1编码时,也可以存的时候用GBK了 Connection con=DriverManager.getConnection("jdbc:mysql://localhost:3306/jsp? useUnicode=true&characterEncoding=GBK","root",""); str1="中文"; String sql2="INSERT INTO test (name) VALUES('"+str1+"')"; 这样也可以很成功的插入了,呵呵
      

  12.   

    在struts中配个 控制器就ok了
      

  13.   

    换了服务器就出现乱码了。说明你程序文件应该没有问题。出问题的是运行环境:
    容器:tomcat?
    数据库?
      

  14.   

    1.页面要全部设置成Utf-8
    2.数据库也要设置成UTF-8
    如果说是mysql的话,真的需要设置一下,它默认的是一个A开头的字体。