http://www.javaresearch.org/article/showarticle.jsp?column=106&thread=19240
这里应该有你想要的

解决方案 »

  1.   

    在连接mysql的时候进行编码con.getConnection("jdbc:mysql://.....?useUnicode=true&characterEncoding=gb2312",.....")
      

  2.   

    修改c:\winnt\my.ini:
    [WinMySQLAdmin]
    Server=C:/mysql/bin/mysqld-nt.exe
    [mysqld]
    default-character-set=gb2312
    试试
      

  3.   

    在web.xml中添加:
     <filter>
    <filter-name>Set Character Encoding</filter-name>
    <filter-class>com.chaozi.change.CharacterEncodingFilter</filter-class>
    <init-param>
    <param-name>encoding</param-name>
    <param-value>GB2312</param-value>
    </init-param>
    <init-param>
    <param-name>ignore</param-name>
    <param-value>true</param-value>
    </init-param>
    </filter>
    <filter-mapping>
    <filter-name>Set Character Encoding</filter-name>
    <url-pattern>/*</url-pattern>  
    </filter-mapping>
    com.chaozi.change.CharacterEncodingFilter为类。
      

  4.   

    package com.chaozi.change;/**
     * <p>Title: </p>
     * <p>Description: </p>
     * <p>Copyright: Copyright (c) 2004</p>
     * <p>Company: </p>
     * @author unascribed
     * @version 1.0
     *//*
     * Created on 2004-3-8
     *
     * To change the template for this generated file go to
     * Window&gt;Preferences&gt;Java&gt;Code Generation&gt;Code and Comments
     */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;
    /**
    * <p>Filter that sets the character encoding to be used in parsing the
    * incoming request, either unconditionally or only if the client did not
    * specify a character encoding. Configuration of this filter is based on
    * the following initialization parameters:</p>
    * <ul>
    * <li><strong>encoding</strong> - The character encoding to be configured
    * for this request, either conditionally or unconditionally based on
    * the <code>ignore</code> initialization parameter. This parameter
    * is required, so there is no default.</li>
    * <li><strong>ignore</strong> - If set to "true", any character encoding
    * specified by the client is ignored, and the value returned by the
    * <code>selectEncoding()</code> method is set. If set to "false,
    * <code>selectEncoding()</code> is called <strong>only</strong> if the
    * client has not already specified an encoding. By default, this
    * parameter is set to "true".</li>
    * </ul>
    *
    * <p>Although this filter can be used unchanged, it is also easy to
    * subclass it and make the <code>selectEncoding()</code> method more
    * intelligent about what encoding to choose, based on characteristics of
    * the incoming request (such as the values of the <code>Accept-Language</code>
    * and <code>User-Agent</code> headers, or a value stashed in the current
    * user's session.</p>
    *
    * @author <a href="mailto:[email protected]">John Wong</a>
    *
    * @version $Id: SetCharacterEncodingFilter.java,v 1.1 2002/04/10 13:59:27 johnwong Exp $
    */
    public class CharacterEncodingFilter implements Filter { // ----------------------------------------------------- Instance Variables /**
    * The default character encoding to set for requests that pass through
    * this filter.
    */
    protected String encoding = null; /**
    * The filter configuration object we are associated with. If this value
    * is null, this filter instance is not currently configured.
    */
    protected FilterConfig filterConfig = null; /**
    * Should a character encoding specified by the client be ignored?
    */
    protected boolean ignore = true; // --------------------------------------------------------- Public Methods /**
    * Take this filter out of service.
    */
    public void destroy() { this.encoding = null;
    this.filterConfig = null; } /**
    * Select and set (if specified) the character encoding to be used to
    * interpret request parameters for this request.
    *
    * @param request The servlet request we are processing
    * @param result The servlet response we are creating
    * @param chain The filter chain we are processing
    *
    * @exception IOException if an input/output error occurs
    * @exception ServletException if a servlet error occurs
    */
    public void doFilter(
    ServletRequest request,
    ServletResponse response,
    FilterChain chain)
    throws IOException, ServletException { // Conditionally select and set the character encoding to be used
    if (ignore || (request.getCharacterEncoding() == null)) {
    String encoding = selectEncoding(request);
    if (encoding != null)
    request.setCharacterEncoding(encoding);
    } // Pass control on to the next filter
    chain.doFilter(request, response);
    } /**
    * Place this filter into service.
    *
    * @param filterConfig The filter configuration object
    */
    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 if (value.equalsIgnoreCase("yes"))
    this.ignore = true;
    else
    this.ignore = false; } // ------------------------------------------------------ Protected Methods /**
    * Select an appropriate character encoding to be used, based on the
    * characteristics of the current request and/or filter initialization
    * parameters. If no character encoding should be set, return
    * <code>null</code>.
    * <p>
    * The default implementation unconditionally returns the value configured
    * by the <strong>encoding</strong> initialization parameter for this
    * filter.
    *
    * @param request The servlet request we are processing
    */
    protected String selectEncoding(ServletRequest request) { return (this.encoding); }} //EOC
      

  5.   

    在<BODY>中加下列试试:
    <%
    //中文字体转换问题的解决
    request.setCharacterEncoding("GBK");
    %>
      

  6.   

    Goal3(拼命三郎)的方法已经可以了,但在最新版的mysql中已经解决了这个问题了.我决得是你在插入数据的时候已经变成了乱码吧,因为除了在输出的时候在插入的时候也会出现这种事情,所以在插入之前你先用getByte把中文转成gb2312那应该就没有问题了.格式如:
    String aaa="乱码的中文";
    try{aaa=new String(aaa.getBytes("iso8859_1"),"gb2312");}catch(Exception e){}
      

  7.   

    把mysql设置一下
    修改c:\winnt\my.ini:
    [mysqld]
    default-character-set=gbk然后在程序里边
    String strUrl ="jdbc:mysql://" + ip + ":3306/xmfyt?useUnicode=true&characterEncoding=gbk"; 
    String sex = request.getParameter("sexbutton");
    byte B[]=sex.getBytes("ISO-8859-1"); 
    username=new String(B); 
      

  8.   

    不知道
    mysql-4.0.23 用的编码是什么??
      

  9.   

    用UTF-8
    可以用editplus来打开,另存为utf-8格式参数传递取值时转码:
    <%
    //中文字体转换问题的解决
    request.setCharacterEncoding("UTF-8");
    %>