有多種
(1)在Mysql目錄下找到my.ini
開啟,找到default-character-set設定,把它改成:
default-character-set=gb2312
如果是5.0或更高版本,可以在配置面板裡設定:
詳見:http://ycoe.cnblogs.com/articles/354485.html
(2)String newName = new String(name.getBytes("iso-8859-1"),"gbk");
1、確定你在安 Mysql時的字元集是 gbk
------>1、 <%@ page language="java" pageEncoding="UTF-8"%>
------>2、 如果你在JSP裡有中文,好那可以正常顯示,加上一個struts標籤的form 也有正常的顯示為中文,但是當你在表單 裡提交中文的時候就會變成亂碼
------>3、 變成亂碼以後在與資料庫的資料進行比較的時候就會出錯,而且倒回表單時你會看到?????的亂碼
------>4、 解決辦法是 把 <%@ page language="java" pageEncoding="UTF-8"%> 刪除掉 在第一行加上
<%@ page contentType="text/html;charset=gb2312"%>
和在
<head><meta http-equiv="Content-Type" content="text/html; charset=GB2312" /></head>
(注意一定在head裡第一行)
------>5、當用post提交資料時,也會變成亂碼,解決辦法是
把專案檔下的 WEB-INF/web.xml
加上以下代碼
<filter>
<filter-name>Set Character Encoding</filter-name>
<filter-class>filters.SetCharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>GBK</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>Set Character Encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
然後把servlet裡的WEB-INF/classes/filter目錄拷貝到項目裡對應的目錄,這樣就可以解決因post提交引起的中文問題
OK!改成STRUTS中文問題
servlet的中文問題
response.setContentType("text/html;charset=gb2312");
request.setCharacterEncoding("GB2312");
struts 中文問題
把資源檔用native2ascii.exe 編譯一下,放在原來的位置就可以啦