1、JSP頁(yè)面亂碼
這種亂碼的原因是應(yīng)為沒有在頁(yè)面里指定使用的字符集編碼,解決方法:只要在頁(yè)面開始地方用下面代碼指定字符集編碼即可,<%@ page contentType="text/html; charset=gb2312"? %>
2、數(shù)據(jù)庫(kù)亂碼
這種亂碼會(huì)使你插入數(shù)據(jù)庫(kù)的中文變成亂碼,或者讀出顯示時(shí)也是亂碼,解決方法如下:
在數(shù)據(jù)庫(kù)連接字符串中加入編碼字符集
String Url="jdbc:mysql://localhost/digitgulf?user=root&password=root&useUnicode=true&characterEncoding=GB2312";
并在頁(yè)面中使用如下代碼:
response.setContentType("text/html;charset=gb2312");
request.setCharacterEncoding("gb2312");
3、中文作為參數(shù)傳遞亂碼
當(dāng)我們把一段中文字符作為參數(shù)傳遞個(gè)另一頁(yè)面時(shí),也會(huì)出現(xiàn)亂碼情況,解決方法如下:
在參數(shù)傳遞時(shí)對(duì)參數(shù)編碼,比如
RearshRes.jsp?keywords=" + java.net.URLEncoder.encode(keywords)
然后在接收參數(shù)頁(yè)面使用如下語(yǔ)句接收
keywords=new String(request.getParameter("keywords").getBytes("8859_1"));
以上為現(xiàn)階段遇到的亂碼問(wèn)題,亂碼的核心問(wèn)題還是字符集編碼問(wèn)題,只要掌握了這一點(diǎn),一般的亂碼問(wèn)題都可以解決。
大家在JSP的開發(fā)過(guò)程中,經(jīng)常出現(xiàn)中文亂碼的問(wèn)題,可能一至困擾著大家,現(xiàn)把JSP開發(fā)中遇到的中文亂碼的問(wèn)題及解決辦法寫出來(lái)供大家參考。首先了解一下 Java中文問(wèn)題的由來(lái):Java的內(nèi)核和class文件是基于unicode的,這使Java程序具有良好的跨平臺(tái)性,但也帶來(lái)了一些中文亂碼問(wèn)題的麻煩。原因主要有兩方面,Java和JSP文件本身編譯時(shí)產(chǎn)生的亂碼問(wèn)題和Java程序于其他媒介交互產(chǎn)生的亂碼問(wèn)題。首先Java(包括JSP)源文件中很可能包含有中文,而Java和JSP源文件的保存方式是基于字節(jié)流的,如果Java和JSP編譯成class文件過(guò)程中,使用的編碼方式與源文件的編碼不一致,就會(huì)出現(xiàn)亂碼。基于這種亂碼,建議在Java文件中盡量不要寫中文(注釋部分不參與編譯,寫中文沒關(guān)系),如果必須寫的話,盡量手動(dòng)帶參數(shù)-ecoding GBK或-ecoding gb2312或-ecoding UTF-8編譯;對(duì)于JSP,在文件頭加上<%@ page contentType="text/html;charset=GBK"%>或
<%@ page contentType="text/html;charset=gb2312"%>基本上就能解決這類亂碼問(wèn)題。
下面是一些常見中文亂碼問(wèn)題的解決方法( 下面例子中ecoding采用的是gb2312,也可設(shè)為ecoding GBK或ecoding UTF-8 ):
一、 JSP頁(yè)面亂碼
這種亂碼問(wèn)題比較簡(jiǎn)單,一般是頁(yè)面編碼不一致導(dǎo)致的亂碼,一般新手容易出現(xiàn)這樣的問(wèn)題,具體分以下兩種情況:
? 未指定使用字符集編碼
下面的顯示頁(yè)面(display.jsp)就出現(xiàn)亂碼:
< html > < head > < title > JSP的中文處理 </ title > < meta http-equiv ="Content-Type" content ="text/html charset=gb2312" > </ head > < body > <% out.print( " JSP的中文處理 " ); %> </ body > </ html >
這種亂碼的原因是沒有在頁(yè)面里指定使用的字符集編碼,JSP頁(yè)面中出現(xiàn)了中文字符,而默認(rèn)的ISO-8859-1字符集中無(wú)中文字符,解決方法:只要在頁(yè)面開始地方用下面代碼指定字符集編碼即可,在JSP頁(yè)面中指定編碼方式(gb2312),和瀏覽器解碼方式設(shè)置相同,即在頁(yè)面的第一行加上:
<%@ page contentType="text/html; charset=gb2312"%>,就可以消除亂碼了。
完整頁(yè)面如下:
<% @ page contentType = " text/html; charset=gb2312 " %> < html > < head > < title > JSP的中文處理 </ title > < meta http-equiv ="Content-Type" content ="text/html charset=gb2312" > </ head > < body > <% out.print( " JSP的中文處理 " ); %> </ body > </ html >
? 編碼字符集設(shè)置不一致
下面的顯示頁(yè)面(display.jsp)就出現(xiàn)亂碼:
<% @ page language = " java " pageEncoding = " gb2312 " %> <% @ page contentType = " text/html;charset=iso8859-1 " %> < html > < head > < title > JSP的中文處理 </ title > < meta http-equiv ="Content-Type" content ="text/html charset=gb2312" > </ head > < body > <% out.print( " JSP的中文處理 " ); %> </ body > </ html >
這個(gè)出現(xiàn)亂碼原因是由于頁(yè)面編碼不一致導(dǎo)致的亂碼,在這個(gè)例子中我們可以看到有三處設(shè)置字符集的地方,下面分別了解一下這三處設(shè)置具體含義:
第一處<%@ page language="java" pageEncoding="gb2312"%>的編碼格式為jsp文件的存儲(chǔ)格式。Eclipse會(huì)根據(jù)這個(gè)編碼格式保存文件。并編譯jsp文件,包括里面的漢字。
第二處編碼為解碼格式。因?yàn)榇鏋間b2312的文件被解碼為iso8859-1,這樣如有中文肯定出亂碼。也就是必須一致。而第二處所在的這一行,可以沒有。缺省也是使用iso8859-1的編碼格式。所以如果沒有這一行的話,也會(huì)出現(xiàn)亂碼。必須一致才可以。
第三處編碼為控制瀏覽器的解碼方式。如果前面的解碼都一致并且無(wú)誤的話,這個(gè)編碼格式用不用設(shè)置都可以。有的網(wǎng)頁(yè)出現(xiàn)亂碼,就是因?yàn)闉g覽器不能確定使用哪種編碼格式。因?yàn)轫?yè)面有時(shí)候會(huì)嵌入頁(yè)面,導(dǎo)致瀏覽器混淆了編碼格式出現(xiàn)了亂碼。
完整解決代碼如下:
<% @ page language = " java " pageEncoding = " gb2312 " %> <% @ page contentType = " text/html;charset= gb2312 " %> < html > < head > < title > JSP的中文處理 </ title > < meta http-equiv ="Content-Type" content ="text/html charset=gb2312" > </ head > < body > <% out.print( " JSP的中文處理 " ); %> </ body > </ html >
二、 表單提交中文時(shí)出現(xiàn)亂碼
下面是一個(gè)提交頁(yè)面(submit.jsp),代碼如下:
<% @ page contentType = " text/html; charset=gb2312 " %> < html > < head >< title > JSP的中文處理 </ title > < meta http-equiv ="Content-Type" content ="text/html; charset=gb2312" > </ head > < body > < form name ="form1" method ="post/get" action ="process.jsp" > < div align ="center" > < input type ="text" name ="name" > < input type ="submit" name ="Submit" value ="Submit" > </ div > </ form > </ body > </ html >
下面是處理頁(yè)面(process.jsp)代碼:
<% @ page contentType = " text/html; charset=gb2312 " %> < html > < head > < title > JSP的中文處理 </ title > < meta http-equiv ="Content-Type" content ="text/html; charset=gb2312" > </ head > < body > <% = request.getParameter( " name " ) %> </ body > </ html >
如果submit.jsp提交英文字符能正確顯示,如果提交中文時(shí)就會(huì)出現(xiàn)亂碼。原因:瀏覽器默認(rèn)使用UTF-8編碼方式來(lái)發(fā)送請(qǐng)求,而UTF- 8和GB2312編碼方式表示字符時(shí)不一樣,這樣就出現(xiàn)了不能識(shí)別字符。
? POST提交方式
解決辦法:
A、 接受參數(shù)時(shí)進(jìn)行編碼轉(zhuǎn)換
String s=new String(request.getParameter("name").getBytes("ISO-8859-1"),"gb2312") ;
修改后的process.jsp代碼如下:
<% @ page contentType = " text/html; charset=gb2312 " %> < html > < head > < title > JSP的中文處理 </ title > < meta http-equiv ="Content-Type" content ="text/html; charset=gb2312" > </ head > < body > <% String s = new String (request.getParameter( " name " ).getBytes( " ISO-8859-1 " ), " gb2312 " ) ; out.print(s); %> </ body > </ html >
如果使用該方法的話,每一個(gè)參數(shù)都必須這樣進(jìn)行轉(zhuǎn)碼。很麻煩。但確實(shí)可以拿到漢字。
B、通過(guò)request.seCharacterEncoding ("gb2312")對(duì)請(qǐng)求進(jìn)行統(tǒng)一編碼,就實(shí)現(xiàn)了中文的正常顯示。
修改后的process.jsp代碼如下:
<% @ page contentType = " text/html; charset=gb2312 " %> <% request.seCharacterEncoding( " gb2312 " ); %> < html > < head > < title > JSP的中文處理 </ title > < meta http-equiv ="Content-Type" content ="text/html; charset=gb2312" > </ head > < body > <% = request.getParameter( " name " ) %> </ body > </ html >
如果使用該方法接受此參數(shù)的頁(yè)面就不必在轉(zhuǎn)碼了,即可得到漢字參數(shù)。但每頁(yè)都需要執(zhí)行這句話。
C、為了避免每頁(yè)都要寫request.setCharacterEncoding("gb2312"),可以使用過(guò)濾器對(duì)所有jsp
進(jìn)行編碼處理。就是使用Servlet規(guī)范中的過(guò)慮器指定編碼,主要代碼如下:
import java.io. * ; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; public class SetCharacterEncodingFilter implements Filter { protected String encoding = null ; public void destroy(){ this .encoding = null ; } public void init(FilterConfig filterConfig) throws ServletException { this .encoding = filterConfig.getInitParameter( " encoding " ); } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { request.setCharacterEncoding(encoding); response.setContentType( " text/html;charset= " + encoding); chain.doFilter(request, response); } }
過(guò)濾器在web.xml中的配置如下:
< filter > < filter-name > SetCharacterEncodingFilter </ filter-name > < filter-class > SetCharacterEncodingFilter </ filter-class > < init-param > < param-name > encoding </ param-name > < param-value > gb2312 </ param-value > </ init-param > </ filter > < filter-mapping > < filter-name > SetCharacterEncodingFilter </ filter-name > < url-pattern > /* </ url-pattern > </ filter-mapping >
修改后的process.jsp代碼如下:
<% @ page contentType = " text/html; charset=gb2312 " %> < html > < head > < title > JSP的中文處理 </ title > </ head > < body > <% = request.getParameter( " name " ) %> </ body > </ html >
以上方法只對(duì)POST方式提交有效果。
? GET提交方式
如果使用get方式提交中文,接受參數(shù)的頁(yè)面也會(huì)出現(xiàn)亂碼,這個(gè)亂碼的原因也是tomcat的內(nèi)部編碼格式iso8859-1導(dǎo)致。Tomcat會(huì)以get的缺省編碼方式iso8859-1對(duì)漢字進(jìn)行編碼,編碼后追加到url,導(dǎo)致接受頁(yè)面得到的參數(shù)為亂碼。
解決辦法:
A、 使用POST提交方式解決辦法的第一種方式,對(duì)接受到的字符進(jìn)行解碼,再轉(zhuǎn)碼。
B 、首先配置tomcat下server.xml的Connector節(jié)點(diǎn)增加useBodyEncodingForURI="true"屬性配置,然后在JSP頁(yè)面中加入<%request.seCharacterEncoding("gb2312");%>所設(shè)置的編碼格式進(jìn)行編碼。
1、Tomcat中server.xml配置如下:
< Connector port ="8080" protocol ="HTTP/1.1" connectionTimeout ="20000" redirectPort ="8443" useBodyEncodingForURI ="true" />
2、修改后的process.jsp代碼如下:
<% @ page contentType = " text/html; charset=gb2312 " %> <% request.seCharacterEncoding( " gb2312 " ); %> < html > < head > < title > JSP的中文處理 </ title > < meta http-equiv ="Content-Type" content ="text/html; charset=gb2312" > </ head > < body > <% = request.getParameter( " name " ) %> </ body > </ html >
三、數(shù)據(jù)庫(kù)連接出現(xiàn)亂碼
這種亂碼會(huì)使你插入數(shù)據(jù)庫(kù)的中文變成亂碼,或者讀出顯示時(shí)也是亂碼,解決方法如下: 在數(shù)據(jù)庫(kù)連接字符串中加入編碼字符集
String Url=" jdbc:sqlserver://localhost:1433; DataBaseName=mydb;user=sa&password=sa&useUnicode=true&characterEncoding=GB2312";
并在JSP頁(yè)面中使用如下代碼:
response.setContentType(
"
text/html;charset=gb2312
"
); request.setCharacterEncoding(
"
gb2312
"
);
四、關(guān)于jsp在MyEclipse中打開的亂碼問(wèn)題
對(duì)于一個(gè)已經(jīng)存在的項(xiàng)目,Jsp文件的存儲(chǔ)格式可能是utf-8。如果新安裝的eclipse,則缺省打開使用的編碼格式可能iso8859-1。所以導(dǎo)致 jsp里面的漢字出現(xiàn)亂碼。這個(gè)亂碼魚解決方式如下:
A、Myeclispe Window - > Preferences彈出屬性窗口
General - > Workspace 設(shè)置Text file encoding 全局設(shè)置。
B、右鍵你的項(xiàng)目---屬性---Text file encoding 項(xiàng)目設(shè)置
五、關(guān)于html頁(yè)面在eclipse中打開出現(xiàn)亂碼情況
由于大部分頁(yè)面都是由dreamweaver制作,其存儲(chǔ)格式跟eclipse的識(shí)別有差別導(dǎo)致。
一般這種情況,在eclipse中新建一個(gè)jsp,直接從dreamweaver復(fù)制頁(yè)面內(nèi)容粘貼到j(luò)sp即可。
六、JSP頁(yè)面通過(guò)URL傳遞中文參數(shù)的亂碼問(wèn)題
在項(xiàng)目中,我們經(jīng)常遇到需要在jsp頁(yè)面切換中傳遞中文字符。例如:http://website/test1.jsp?act=add&type=蘋果
? 一般來(lái)說(shuō)我們很少直接在URL里面把參數(shù)寫成中文,如例子中的"type=蘋果"這樣傳遞。如果出現(xiàn)這種情況,在我們的接收參數(shù)的頁(yè)面我們只需要做個(gè)簡(jiǎn)單的轉(zhuǎn)換就可以了。
代碼test1.jsp:(主要部分)
<% @ page language = " java " import = " java.util.* " pageEncoding = " gb2312 " %> <% String type = request.getParameter( " type " ); String result = new String (type.getBytes( " iso-8859-1 " ), " gb2312 " ); out.println(result); %>
? 更普遍的做法,就是對(duì)url中的中文字符進(jìn)行編碼,變成類似type=%20D%20B這樣的字符。
代碼MyJsp1.jsp:
<% @ page language = " java " import = " java.util.* " pageEncoding = " gb2312 " %> <% @ page import = " java.net.* " %> < a href ='./MyJsp2.jsp?act=<%=URLEncoder.encode("中國(guó)人 非常好")% > '>test </ a >
代碼MyJsp2.jsp:
<% @ page language = " java " import = " java.util.* " pageEncoding = " gb2312 " %> <% @ page import = " java.net.* " %> <% String tempVal = URLDecoder.decode(request.getParameter( " act " )); out.println( new String (tempVal.getBytes( " ISO-8859-1 " ), " gb2312 " )); %>
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
