回 帖 发 新 帖 刷新版面

主题:[讨论]麻烦高手帮看看这段解决乱码的代码什么地方有问题!

我使用的是MYSQL5.0.20+tomcat5.0.16+XP+IIS
网页编码统一采用<%@ page contentType="text/html; charset=GBK"language="java" buffer="32kb"%>而起还设置了统一请求request.setCharacterEncoding("GBK");!
字符转化编码的类:
* 函数名:getStrCN
    * 作  用:转化字符编码
    * 参  数:数组 s1:等转化的字符
    * 返回值:转化以后的字符串
    ***********************************************************/
    public String getStrCN(String s)
    {
        if(s == null) s = "";
        try
        {
            byte abyte0[] = s.getBytes("GBK");
            s = new String(abyte0);
        }catch(Exception e) {s="";}
        return s;
    }
数据在MYSQL中能正确显示,但<%=*%>方法输出和out.println输出都是乱码,到底是那里错错了啊!麻烦指正!小弟刚学!谢谢!!!!!            

回复列表 (共1个回复)

沙发

[转帖]

1、在jsp页中加入一条语句: 
<%@ page contentType="text/html;charset=gb2312" %>中文显示就正常了。 

2、对于从网页中的文本框通过String parameter = request.getParameter(“parameter”);方式获得的字符串,均是8859_1的编码, 
如果想把它显示在网页上就必须得用parameter = new String(parameter.getBytes(“8859_1”),”gb2312”)进行转换,windows和linux这两种系统都是一样的。 
有一个简单方法,就是在 getParameter() 方法获取参数之前,使用request.setCharacterEncoding("GB2312");,将提交的信息转化为 GB2312 编码。 


3、但是对于将数据写入数据库的问题,采取的方式就不同了: 
windows下,必须要采用该字符串转换再插入数据库,而linux下就不需要,而是直接把8859_1编码的字符插入。 
如果从数据库中读出的数据,对于windows因为在插入时已经做了转换,所以读出时已经是gb2312的,当把它显示在网页上时,不需要做编码转换,而 linux上的mysql中的数据是8859_1的所以要做编码的转换。 

4、 如果你给某个字符串变量赋予一个中文字符串的值,那么在你取出他时,在网页上的显示是不需要做字符转换的, 
但是如果你要在linux下做字符的比较,则还需要把字符做parameter = new String(parameter.getBytes(“gb2312”),”8859_1”)的转换。

我来回复

您尚未登录,请登录后再回复。点此登录或注册