java;jsp;tomcat;mysql;hibernate;編碼中文亂碼全面解決方案

來源:互聯網
上載者:User

首先說在java裡那些地方能夠設定編碼
開發工具會有好多地方設定編碼這個不解少了,這裡不介紹了。

下面兩種設定編碼格式方法適用於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");

下面適合html頁面(*.htm;*.html)
<meta http-equiv="content-type" content="text/html; charset=UTF-8">

Tomcate設定編碼(server.xml)
<Connector 其他省略 port="80" URIEncoding="UTF-8">

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;

my.ini中配置預設編碼
default-character-set=utf8

串連資料庫設定編碼
jdbc:mysql://192.168.0.5:3306/test?characterEncoding=utf8

/*****************************************java與mysq編碼對應****************************************/

java中的常用編碼UTF-8;GBK;GB2312;ISO-8859-1;
對應mysql資料庫中的編碼utf8;gbk;gb2312;latin1

/********************************************過濾器使用*********************************************/

//過濾器設定編碼過濾(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>

/************************有了上面的基礎下面試完滿解決方案*****************************************/

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結構和資料時存在亂碼

在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

2. 修改MySql資料庫的my.ini設定檔

[client]

port=3306

default-character-set=GBK

#此處預設編碼修改為GBK或utf-8

3、建立資料表的時候

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=gbk;

此處要用GBK編碼

4、在jsp頁面中使用UTF-8編碼

5. 加個filter

6. 在表的欄位後加 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
);

7. mysql 中 的 status 命令:

如果 client characterset 不是 gbk 或 utf8 那麼可能出現插入資料時查出來是亂碼,解決方案:用mysql 設定軟體佈建,手工用命令列,可能是命令不對的緣故,搞了好就都不行

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.