3.redirectPort=“8443” URIEncoding=“UTF-8”/>
②編寫過濾器Filter Java代碼
1.2.import java.io.IOException;3.4.import javax.servlet.Filter;5.import javax.servlet.FilterChain;6.import javax.servlet.FilterConfig;7.import javax.servlet.ServletException;8.import javax.servlet.ServletRequest;9.import javax.servlet.ServletResponse;10.11.public class CharacterEncodingFilter implements Filter...{
http://58andy.sinaapp.com 12.13.@Override
14.public void destroy()...{ 15.} 16.17.@Override
18.public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException,ServletException { 19.request.setCharacterEncoding(“utf-8”);20.chain.doFilter(request, response);21.} 22.23.@Override
24.public void init(FilterConfig arg0)throws ServletException...{ 25.} 26.27.}
利用過濾器,把requst傳遞的中文參數(shù)都設(shè)成“UTF-8”編碼。
③修改web.xml文件
打開項(xiàng)目里的web.xml文件,在前面加上如下代碼: Xml代碼
1.2.
3.characterEncoding
4.com.v512.example.CharacterEncodingFilter 5.
6.
7.characterEncoding 8./* 9.
注意其過濾的URL為“/*”,表示當(dāng)前的request請(qǐng)求。為了使設(shè)置生效,重起tomcat。
㈢國際化資源文件亂碼
http://58andy.sinaapp.com
①利用JDK的native2ascii工具進(jìn)行編碼轉(zhuǎn)換
國際化問題,主要是為了處理文件在瀏覽器上的顯示問題,還是以登錄界面來說,比如在中文瀏覽器上,我們要看到中文顯示,對(duì)應(yīng)在英文瀏覽器上要顯示英文。那么我們?cè)诘卿浤莻€(gè)界面處理上,就不能直接寫上我們的“用戶名”“密碼”等標(biāo)識(shí)了。就要用標(biāo)記轉(zhuǎn)換輸出了,修改為: Html代碼
1.2.
再者,打開項(xiàng)目下的資源配置文件ApplicationResources.properties,依據(jù)上面所寫key值,設(shè)定成我們要的默認(rèn)值(顯示英文),比如 引用
#Resource for Parameter 'com.v512.example.struts.ApplicationResources #Project webexample2 example.login.username=username example.login.password=password
現(xiàn)在我們動(dòng)手新建一個(gè)資源文件,讓其能顯示中文,直接Ctrl+C,Ctrl+V。改名為ApplicationResources_zh.properties,代碼如下: 引用
#Resource for Parameter 'com.v512.example.struts.ApplicationResources #Project webexample2 example.login.username=用戶名 example.login.password=密碼
但保存,myeclipse會(huì)報(bào)錯(cuò),這時(shí)我們需要修改資源文件的編碼格式。Windons---->Preferences---->Content Type------>Text----->JavaPropertiesFile,把其Default encoding改為“utf-8”,按“update”更新。這樣就能進(jìn)行保存了。但是當(dāng)我們進(jìn)行驗(yàn)證會(huì)不是成功時(shí),仍然給我們的是亂碼。
不急,我們還得做一項(xiàng)任務(wù),打開DOS窗口,CMD到資源文件所在目錄,運(yùn)用JDK的native2ascii工具把我們新建的資源文件改成另一個(gè)名字的資源文件,例如bank.properties。命令如下: 引用
>native2ascii-encoding gbk ApplicationResources_zh.properties bank.properties
http://58andy.sinaapp.com
打開bank.properties資源文件,自動(dòng)生成的代碼如下: 引用
#Generated by ResourceBundle Editor(http://eclipse-rbe.sourceforge.net)
example.login.username = u7528u6237u540D example.login.password = u5BC6u7801
然后在myeclipse窗口中,把原來新建ApplicationResources_zh.properties 刪除,并把bank.properties改為ApplicationResources_zh.properties(為了方便記憶,管理)。然后重起tomcat或進(jìn)行reload文件,我們發(fā)現(xiàn)亂碼問題沒有了。
②利用Eclipse ResourceBundle Editor插件工具
以上我們是利用了JDK的native2ascii工具來處理國際化問題,但在EC中,還有一種更方便的工具專門用來處理編輯java的資源文件國際化亂碼問題,即Eclipse ResourceBundle Editor插件工具。安裝了這個(gè)插件后,我們能進(jìn)行方便的可視化資源文件編輯。推薦。
PHP亂碼?Mysql亂碼?怎么解決?
PHP亂碼或者mysql亂碼,多半是因?yàn)闆]有統(tǒng)一編碼,要解決PHP/mysql亂碼,只要做到三碼合一即可.所謂三碼,是指文件編碼,頁面編碼聲明和數(shù)據(jù)庫字符集,要使用相同的編碼,如全部為utf-8.怎么做到三碼合一?下面以u(píng)tf-8為例,說明如何統(tǒng)一編碼.1.網(wǎng)頁文件編碼保存為utf-8無BOM
記事本,保存文件的時(shí)候選擇“編碼”為utf-8
editPlus,保存時(shí)選擇“encoding”為utf-8
UEStudio保存時(shí)選擇“格式”為utf-8無BOM
2.PHP頁面內(nèi)部使用header('Content-type : text/html;Charset=UTF-8');聲明頁面編碼為utf-8
在html頭部寫入來聲明頁面編碼為utf-8
3.PHP頁面中連接數(shù)據(jù)庫服務(wù)器后執(zhí)行sql查詢前使用以下代碼先將字符集設(shè)置為utf-8 mysql_query('SET NAMES utf8');[或mysqli,具體代碼這里不再寫了]
4.創(chuàng)建數(shù)據(jù)表的時(shí)候?qū)⒛J(rèn)編碼設(shè)置為utf8,將字符校對(duì)(callate)設(shè)置為utf8_general_ci CREATE TABLE IF NOT EXISTS `name`(....代碼....)ENGINE InnoDB DEFAULT CHARSET utf8 COLLATE utf8_general_ci
做到這四點(diǎn),相信你的網(wǎng)頁和數(shù)據(jù)庫不會(huì)再亂碼.
phpmyadmin亂碼問題____2012年12月6日 09:39:16
首先,如果你出現(xiàn)亂碼,你一定baidu了文章,對(duì)于各種答案,肯定是頭都大了,說的都差不多,卻都不一樣煩啊。問題敘述:
1,從網(wǎng)頁提交數(shù)據(jù)庫數(shù)據(jù),在phpmyadmin上顯示亂碼,在網(wǎng)頁輸出是好的2,直接從數(shù)據(jù)庫插入數(shù)據(jù),但是輸出到網(wǎng)頁后是亂碼
3,從網(wǎng)頁提交數(shù)據(jù)庫數(shù)據(jù),在phpmyadmin上顯示正確,但是網(wǎng)頁輸出是亂碼。
對(duì)于亂碼問題就這三種了吧!
今天我親自試驗(yàn)了一下,下面公布我的結(jié)果(我用的是UTF-8,其他同理,UTF-8特別注意)
總述,亂碼,原因,編碼不一致,為什么?答曰:提交數(shù)據(jù)庫的數(shù)據(jù)需要編碼,數(shù)據(jù)庫存儲(chǔ)需要編碼,從數(shù)據(jù)庫提取的數(shù)據(jù)還需要編碼。這三種編碼需要一致!
首先,你要保證所有輸出輸入網(wǎng)頁都有編碼聲明
或者
header(“Content-Type: text/html;charset=utf-8”);
header(“Content-Type: text/html;charset=utf-8”);
注意!這里是utf-8,不是utf8
其次,相應(yīng)數(shù)據(jù)的編碼整理應(yīng)該為utf8_general_ci。
1、從網(wǎng)頁提交數(shù)據(jù)庫數(shù)據(jù),在phpmyadmin上顯示亂碼,在網(wǎng)頁輸出是好的,說明提交的數(shù)據(jù)和數(shù)據(jù)庫的編碼不一樣,提取數(shù)據(jù)的編碼和提交數(shù)據(jù)的編碼一樣 A->B->A型
這你就懂了吧,A是提交和提取數(shù)據(jù)的編碼,B是數(shù)據(jù)庫存儲(chǔ)用的編碼。
修改方法: 如果你不是新手的話,數(shù)據(jù)庫連接文件應(yīng)該是單獨(dú)的吧比如execut_dql()(供查詢用)或者execut_dml()(供修改用),所有的語句應(yīng)該都是通過這兩個(gè)函數(shù)進(jìn)行的所以在這兩個(gè)函數(shù)里的第一行,先寫上mysql_query(“SET NAMES 'utf8'”);注意!是utf8,不是utf-8
例如下面的(在mysql_query()你的SQL語句之前,全部 SET NAME 'utf8'一下)
mysql_query(“SET NAMES 'utf8'”);
$res=mysql_query($sql,$this->conn)ordie(mysql_error());
mysql_query(“SET NAMES 'utf8'”);$res=mysql_query($sql,$this->conn)or die(mysql_error());
其實(shí),你把所以關(guān)于數(shù)據(jù)庫查詢、插入的語句前全部mysql_query(“SET NAMES 'utf8'”);后,亂碼問題就已經(jīng)解決了,不過你以前插入的數(shù)據(jù)要重新插入了。
2、直接從數(shù)據(jù)庫插入數(shù)據(jù),但是輸出到網(wǎng)頁后是亂碼。B->A型
這個(gè)不用再說了吧,你把查詢語句前先
mysql_query(“SET NAMES 'utf8'”);
//你的查詢
之后刷新下就不是亂碼了。
3、從網(wǎng)頁提交數(shù)據(jù)庫數(shù)據(jù),在phpmyadmin上顯示正確,但是網(wǎng)頁輸出是亂碼。A->A->B型
同上,你把查詢語句前先
mysql_query(“SET NAMES 'utf8'”);
之后刷新下就不是亂碼了。
所以總結(jié)出,只要保證操作過程中,輸入,存儲(chǔ),輸出的字符編碼一致,你想讓他亂碼都難