美文网首页
JSP乱码问题

JSP乱码问题

作者: 简单Liml | 来源:发表于2017-05-15 09:48 被阅读22次

    大家在JSP的开发过程中,经常出现中文乱码的问题,可能一至困扰着您,我现在把我在JSP开发中遇到

    的中文乱码的问题及解决办法写出来供大家参考。

    一、JSP页面显示乱码

    下面的显示页面(display.jsp)就出现乱码:

    JSP的中文处理

    <%

    out.print("JSP的中文处理");

    %>

    对不同的WEB服务器和不同的JDK版本,处理结果就不一样。原因:服务器使用的编码方式不同和浏览器

    对不同的字符显示结果不同而导致的。解决办法:在JSP页面中指定编码方式(gb2312),即在页面的第一

    行加上:<%@ page contentType="text/html; charset=gb2312"%>,就可以消除乱码了。完整页面如下

    <%@ page contentType="text/html; charset=gb2312"%>

    JSP的中文处理

    <%

    out.print("JSP的中文处理");

    %>

    二、表单提交中文时出现乱码

    下面是一个提交页面(submit.jsp),代码如下:

    JSP的中文处理

    下面是处理页面(process.jsp)代码:

    <%@ page contentType="text/html; charset=gb2312"%>

    JSP的中文处理

    <%=request.getParameter("name")%>

    如果submit.jsp提交英文字符能正确显示,如果提交中文时就会出现乱码。原因:浏览器默认使用UTF

    -8编码方式来发送请求,而UTF- 8和GB2312编码方式表示字符时不一样,这样就出现了不能识别字符。

    解决办法:通过request.seCharacterEncoding ("gb2312")对请求进行统一编码,就实现了中文的正常

    显示。修改后的process.jsp代码如下:

    <%@ page contentType="text/html; charset=gb2312"%>

    <%

    request.seCharacterEncoding("gb2312");

    %>

    JSP的中文处理

    <%=request.getParameter("name")%>

    三、数据库连接出现乱码

    只要涉及中文的地方全部是乱码,解决办法:在数据库的数据库URL中加上

    useUnicode=true&characterEncoding=GBK 就OK了。

    四、数据库的显示乱码

    在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()来转换编码。

    相关文章

      网友评论

          本文标题:JSP乱码问题

          本文链接:https://www.haomeiwen.com/subject/bhncxxtx.html