我每个页面都有写
<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %>
<%  
request.setCharacterEncoding("gb2312");
%>大部分字正常,
但是一些字还是变成乱码
(多为从数据里取的字,数据库中正常,同一页面里,其他从数据库里拿的数据有的也正常),
把gb2312换成GBK效果一样
大概怎么解决

解决方案 »

  1.   

    这段时间经常看到有人问到web开发中怎么中文总是?号。原因其实很简单,因为大家大多用的是tomcat服务器,而tomcat服务器的默认编码为 iso-8859-1(西欧字符)。就是因为iso-8859-1(西欧字符)编码造成了我们经常看到?号。  方法一:最简单也是用的最多的方法。<%@ page language="java" pageEncoding="GBK" %>  或者<%@ page contenttype="text/html;charset=gbk";>这里可以用gb2312或者gbk,只是gbk比gb2312支持跟多的字符。这个方法用于jsp页面中的中文显示。  方法二:使用过滤器。  过滤器使用主要针对表单提交,插入数据库的数据都是?号。这也是应为tomcat不按request所指定的编码进行编码,还是自作主张的采用默认编码方式iso-8859-1编码。  编写一个SetCharacterEncodingFilter类。import java.io.IOException;import javax.servlet.Filter;
    import javax.servlet.FilterChain;
    import javax.servlet.FilterConfig;
    import javax.servlet.ServletException;
    import javax.servlet.ServletRequest;
    import javax.servlet.ServletResponse;public class SetCharacterEncodingFilter implements Filter {
     protected String encoding = null;
     protected FilterConfig filterConfig = null;
     protected boolean ignore = true; public void init(FilterConfig filterConfig) throws ServletException {
      this.filterConfig=filterConfig;
      this.encoding=filterConfig.getInitParameter("encoding");
      String value=filterConfig.getInitParameter("ignore");
      if(value==null)
       this.ignore=true;
      else if(value.equalsIgnoreCase("true"))
       this.ignore=true;
      else
       this.ignore=false;
     } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
     // TODO 自动生成方法存根
     if (ignore || (request.getCharacterEncoding() == null)) {
      String encoding = selectEncoding(request);
      if (encoding != null)
       request.setCharacterEncoding(encoding);
     }
     chain.doFilter(request, response);
    }public void destroy() {
     // TODO 自动生成方法存根
     this.encoding = null;
     this.filterConfig = null;
    }protected String selectEncoding(ServletRequest request) {
     return (this.encoding);
    }
    }   然后再web.xml加上<!-- Set Character Encoding-->
    <filter>
     <filter-name>Set Character Encoding</filter-name>
     <filter-class>com.struts.common.SetCharacterEncodingFilter</filter-class>
     <init-param>
      <param-name>encoding</param-name>
      <param-value>UTF-8</param-value>
     </init-param>
    </filter><filter-mapping>
     <filter-name>Set Character Encoding</filter-name>
      <url-pattern>/*</url-pattern>
     </filter-mapping>
    <!-- Set Character Encoding-->   使用过滤器的好处很多,特别是项目之中。而且在使用国际化时就更有用了,只要在页面指定 <%@ page language="java" pageEncoding="UTF-8" %>,服务器就会根据本地Locale来显示正确的字符集。  所以我特别推荐使用过滤器。  方法三:修改tomcat的server.xml文件中URIEncoding。<Connector debug="0" acceptCount="100" connectionTimeout="20000" disableUploadTimeout="true"
    port="80" redirectPort="8443" enableLookups="false" minSpareThreads="25" maxSpareThreads="75"
    maxThreads="150" maxPostSize="0" URIEncoding="GBK" >
    </Connector>   这个方法主要针对从url中获取字符串的问题。   在tomcat5.0及以上版本,post和get方法在处理编码时有所不同。如果你在url中获取中文就会出现?号。但在tomcat4.1版本没有问题,因为tomcat4.1的post和get方法在处理编码时是一样的。 
      

  2.   

    1.编码问题:
      (1)首先确定JSP页面头部是否有:<%@ page contentType="text/html; charset=GBK" %>
      (2)类似这样的转码:
         String param= new String(request.getParameter("param").getBytes("ISO-8859-1"), "GBK");
      (3)添加filter字符过滤器,具体做法:      先添加类:import javax.servlet.Filter;
    import javax.servlet.FilterConfig;
    import javax.servlet.ServletException;
    import javax.servlet.ServletRequest;
    import javax.servlet.ServletResponse;
    import javax.servlet.FilterChain;
    import java.io.IOException;
    import org.apache.log4j.Logger;
    import java.net.URLEncoder;/** *//**
     * 请求中中文字符串过滤类
     */public class SetEncodingFilter
        implements Filter ...{
      private Logger logger=Logger.getLogger(this.getClass());  public void init(FilterConfig filterConfig) throws ServletException ...{
      }  public void doFilter(ServletRequest request, ServletResponse response,
                           FilterChain chain) throws IOException, ServletException ...{
        logger.info("请求转码过滤器===================");
        request.setCharacterEncoding("gb2312");
        chain.doFilter(request,response);
      }  public void destroy() ...{
      }
    }
         再注册类到XML里:  <filter>
        <filter-name>Set Encoding</filter-name>
        <filter-class>SetEncodingFilter</filter-class>
      </filter>
      <filter-mapping>
        <filter-name>Set Encoding</filter-name>
        <url-pattern>/*</url-pattern>
      </filter-mapping>
       (4)如果是通过"a.jsp?param=中文"传递参数,则需要:
         a.在传参数之前先把参数进行转码:java.net.URLEncoder.encode(param);
           取值用java.net.URLDncoder.dncode(param);再转回中文
         b.在你的Tomcat目录-->conf目录-->server.xml里找出这段:       <Connector 
    port="8080"               maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
                   enableLookups="false" redirectPort="8443" acceptCount="100"
                   debug="0" connectionTimeout="20000" 
                   disableUploadTimeout="true" <!--在里边加上这个参数-->URIEncoding="gb2312"
     /> 
       (5)数据库乱码,首先确定你在插入数据库之前是中文,解决办法:     在数据库的数据库连接URL中加上useUnicode=true&characterEncoding=GBK就OK了。      如果在读取的时候出现乱码用第二种方法解决.http://blog.csdn.net/lip009/archive/2006/09/07/1192022.aspx#521755