java;jsp;tomcat;mysql;hibernate;编码中文乱码全面解决方案

一、Java、JSP编码

开发工具会有好多地方设置编码这个不解少了,这里不介绍了。 
java与mysq编码对应:
java中的常用编码 UTF-8;GBK;GB2312;ISO-8859-1; 
对应mysql数据库中的编码 utf8;gbk;gb2312;latin1 
下面两种设置编码格式方法适用于jsp页面(*.jsp) :
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> 
<%@ page contentType="text/html; charset=UTF-8" %> 
下面方式适合于jsp、servlet、action中(*.java) :
request.setCharacterEncoding("UTF-8"); 
response.setCharacterEncoding("UTF-8"); 
JSP中编码过滤器的使用:
//过滤器设置编码过滤(SetCharacterEncodingFilter.java) 
package com.sorc; 

import java.io.*; 
import javax.servlet.*; 
import javax.servlet.http.*; 

public class SetCharacterEncodingFilter extends HttpServlet implements Filter{ 
   private FilterConfig filterConfig; 
   private String encoding=null; 
   //Handle the passed-in FilterConfig 
   public void init(FilterConfig filterConfig){ 
      this.filterConfig=filterConfig; 
      encoding=filterConfig.getInitParameter("encoding"); 
   } 
   //Process the request/response pair 
   public void doFilter(ServletRequest request,ServletResponse response,FilterChain filterChain){ 
      try{ 
         request.setCharacterEncoding(encoding); 
         filterChain.doFilter(request,response); 
      } catch(ServletException sx){ 
         filterConfig.getServletContext().log(sx.getMessage()); 
      } catch(IOException iox){ 
         filterConfig.getServletContext().log(iox.getMessage()); 
      } 
   } 
   //Clean up resources 
   public void destroy(){ 
   } 

//web.xml配置过滤器方法(web.xmd) 
<filter> 
    <filter-name>setcharacterencodingfilter</filter-name> 
    <filter-class>com.sorc.SetCharacterEncodingFilter</filter-class> 
    <init-param> 
      <param-name>encoding</param-name> 
      <param-value>utf8</param-value> 
    </init-param> 
</filter> 
<filter-mapping> 
    <filter-name>setcharacterencodingfilter</filter-name> 
    <url-pattern>/*</url-pattern> 
</filter-mapping> 
下面适合html页面(*.htm;*.html) :
<meta http-equiv="content-type" content="text/html; charset=UTF-8"> 

二、Tomcat编码

Tomcate设置编码(server.xml) 
<Connector 其他省略 port="80" URIEncoding="UTF-8"> 

三、MySQL编码

mysql设置编码命令 
SET character_set_client = utf8; 
SET character_set_connection = utf8; 
SET character_set_database = utf8; 
SET character_set_results = utf8;/*这里要注意很有用*/ 
SET character_set_server = utf8; 
SET collation_connection = utf8_bin; 
SET collation_database = utf8_bin; 
SET collation_server = utf8_bin; 
修改MySql数据库的my.ini配置文件

[client]

port=3306

default-character-set=utf-8

#此处默认编码修改为GBK或utf-8

连接数据库设置编码 (适用于java,jsp,hibernate)
jdbc:mysql://192.168.0.5:3306/test?characterEncoding=utf8 

创建数据表的时候

CREATE TABLE `article` (

`article_id` varchar(100) NOT NULL default '0',

`article_title` varchar(100) default NULL,

    PRIMARY KEY (`article_id`)

) ENGINE=MyISAM DEFAULT CHARSET=utf-8;

此处要用utf-8编码

在表的字段后加 CHARACTER SET utf8 COLLATE utf8_unicode_ci,如:
username VARCHAR (20) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,

完整的做法是:
drop table IF EXISTS blog;
CREATE TABLE blog( 
id   INTEGER      PRIMARY KEY,
username VARCHAR (20) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,
password VARCHAR (20) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,
subject   VARCHAR (100) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,
email   VARCHAR (50) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,
image   VARCHAR (100) CHARACTER SET utf8 COLLATE utf8_unicode_ci NULL,
visitcount INTEGER    NULL
);

mysql 中 的 status 命令:

如果 client characterset 不是 gbk 或 utf8 那么可能出现插入数据时查出来是乱码,解决方法:用mysql 设置软件设置,手工用命令行,可能是命令不对的缘故,搞了好就都不行


四、Hibernate编码

在hibernate.cfg.xml中应该这样写

< property  name ="connection.url" > jdbc:mysql://localhost:3306/yidishui?useUnicode=true&amp;characterEncoding=UTF-8 </ property >

如果用hibernate.properties
#hibernate.connection.url jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8

五、其他完美解决方案

1.使用GBK编码的解决方案 
这个最简单 遇到设置编码的地方就是用GBK数据库gbk 然后在使用个过滤器过滤编码为gbk一切搞定。 
效果为添加数据无乱码 读出无乱码 数据库管理工具无乱码 到处sql结构和数据无乱码 
2.使用UTF-8编码解决方案 
所有编码都设置为UTF-8 
数据库编码utf8 
设置过滤器编码utf8 
数据库连接?characterEncoding=utf8 
然后在数据库管理工具或mysql命令行 运行 SET character_set_results = gbk; 
效果为添加数据无乱码 读出无乱码 数据库管理工具无乱码 到处sql结构和数据时存在乱码 
3.页面使用UTF8 数据库使用latin1的解决方案 
jap java tomcat 设置为UTF-8 
过滤器 utf8 
数据库连接?characterEncoding=latin1 
数据库其他latin1 
然后在数据库管理工具或mysql命令行 运行 SET character_set_results = gbk; 
效果为添加数据无乱码 读出无乱码 数据库管理工具无乱码 到处sql结构和数据时存在乱码

转载于:https://my.oschina.net/kesar/blog/529027

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值