最近在做項(xiàng)目的時(shí)候,與服務(wù)器交互傳輸信息時(shí),出現(xiàn)中文亂碼問(wèn)題。由于一開(kāi)始對(duì)編碼這個(gè)東西不是很了解,都是一知半解狀態(tài),平時(shí)所謂的程序中的轉(zhuǎn)碼也都是基于僥幸的過(guò)去了,沒(méi)遇到什么問(wèn)題??蛇@次卻沒(méi)這么幸運(yùn)了,中文亂碼。。。。,好了,廢話不多說(shuō)了,直入主題。
成都創(chuàng)新互聯(lián)公司自2013年創(chuàng)立以來(lái),是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元北鎮(zhèn)做網(wǎng)站,已為上家服務(wù),為北鎮(zhèn)各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18980820575
如何才能正確解碼?首先要清楚的知道源數(shù)據(jù)是以什么樣的編碼方式encode過(guò)來(lái)的,然后再以對(duì)應(yīng)的編碼方式decode才能正確解碼,否則就會(huì)變成亂碼!
舉例說(shuō)吧:
以Tomcat作服務(wù)器,默認(rèn)的環(huán)境編碼是ios-8859-1,客戶端編碼方式為UTF-8(通常很多人都喜歡把編碼方式設(shè)置成UTF-8吧,呵呵)。當(dāng)客戶端Get/Post數(shù)據(jù)時(shí),參數(shù)值中包含中文時(shí),這里要注意了,GET/POST是有區(qū)別的:
GET時(shí),Tomcat會(huì)以默認(rèn)的環(huán)境編碼iso-8859-1方式進(jìn)行一番解碼,這樣就會(huì)導(dǎo)致中文的地方變成亂碼了,要想解決這個(gè)問(wèn)題,可以逆編碼一下,new String("亂碼字符串".getBytes("iso-8859-1"), "UTF-8"),就能正常顯示了。
POST時(shí),就不會(huì)先以Tomcat的默認(rèn)編碼時(shí)行解碼,而是以你設(shè)置的過(guò)濾器中的編碼方式來(lái)解碼了(比如你設(shè)置的是UTF-8)。
當(dāng)然還有其它更多的方式和方法,比如你可以在GET方式請(qǐng)求時(shí),進(jìn)行兩次URLEncode.encode("中文", "UTF-8");,這樣Tomcat服務(wù)端只要進(jìn)行一次URLDecode.decode("參數(shù)值", "UTF-8");就可以了。原因是:第一次URLEncode是對(duì)中文轉(zhuǎn)換成%、字母和數(shù)字,第二次URLEncode是對(duì)%、字母和數(shù)字進(jìn)行編碼,因此在Tomcat服務(wù)端默認(rèn)使用iso-8859-1進(jìn)行解碼后的結(jié)果是%、字母和數(shù)字,再URLDecode.decode就可以正常顯示中文。