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

關鍵字:html

*************************************java、jsp中設置編碼******************************************/
首先說在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結構和數據時存在亂碼

以上都不須要頁面或java代碼中手動轉碼java

相關文章
相關標籤/搜索