读书人

java mysql数据库乱码有关问题写代

发布时间: 2012-10-30 16:13:36 作者: rapoo

java mysql数据库乱码问题——写代码一定要细心,不然会郁闷死的

遇到了一个java mysql 的乱码问题,起初是使用javascript对java后台进行传参,有乱码,使用如下代码解决:

?

new String(request.getParameter("collName").getBytes("ISO8859-1"), "UTF-8");

?

我的数据库、jsp页面都统一是UTF-8的编码,也加了过滤器,所以当Myeclipse打印出乱码来时我非常疑惑,调了一个下午,

?

还在CSDN上发了贴,这最让我吐血的一件事,后来经检查,sql写错了,sql = select * from table where name=姓名;

?

sql语句中,字符串应使用引号进行包裹传参,所以,应改为 sql = select * from table where name='姓名'

?

今天写此文章用来警醒自己,以后不要再发同样的错误,下面把过滤器及其配置写一下:

?

过滤器:

?

public class CharacterEncodingFilter implements Filter {       private String edcoding=null;       private FilterConfig filterConfig=null;       private boolean ignore=true;         public void destroy() {            edcoding=null;            filterConfig=null;       }         public void doFilter(ServletRequest request, ServletResponse response,               FilterChain filterChain) throws IOException, ServletException {           if(ignore==true||request.getCharacterEncoding()==null){               String encoding=setCharacterEncoding(request);                 if(encoding!=null){                   request.setCharacterEncoding(encoding);                                    }           }             filterChain.doFilter(request, response);       }         public void init(FilterConfig filterConfig) throws ServletException {           this.filterConfig=filterConfig;           this.edcoding=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 String setCharacterEncoding(ServletRequest request){           return this.edcoding;       }   } 

?

?

在web.xml上的配置:

?

    <filter>          <filter-name>CharacterEncodingFilter</filter-name>          <filter-class>base.filter.CharacterEncodingFilter</filter-class>          <init-param>              <param-name>encoding</param-name>              <param-value>UTF-8</param-value>          </init-param>      </filter>      <filter-mapping>          <filter-name>CharacterEncodingFilter</filter-name>          <url-pattern>/*</url-pattern>      </filter-mapping> 

?

java中解决乱码问题确实麻烦,我给的建议就是统一数据库、jsp页面编码,且编码最好为UTF-8。

?

以前我遇到过一个乱码问题,上传文件时 文件名奇数乱码,偶数正常,查了一下说这是和UTF-8的编码方式有关,但一直

?

没有找到好的解决方法。

读书人网 >其他数据库

热点推荐