方法一:最簡單也是用的最多的方法
?。?@ page language="java" pageencoding="gbk" %>
或者<%@ page contenttype="text/html;charset=gbk";>這里可以用gb2312或者gbk,只是gbk比gb2312支持跟多的字符。
這個(gè)方法用于jsp頁面中的中文顯示。
方法二:使用過濾器
過濾器使用主要針對表單提交,插入數(shù)據(jù)庫的數(shù)據(jù)都是?號。這也是應(yīng)為tomcat不按request所指定的編碼進(jìn)行編碼,還是自作主張的采用默認(rèn)編碼方式iso-8859-1編碼。
編寫一個(gè)setcharacterencodingfilter類。
importjava.io.ioexception;
importjavax.servlet.filter;
importjavax.servlet.filterchain;
importjavax.servlet.filterconfig;
importjavax.servlet.servletexception;
importjavax.servlet.servletrequest;
importjavax.servlet.servletresponse;
publicclasssetcharacterencodingfilterimplementsfilter{
protectedstringencoding=null;
protectedfilterconfigfilterconfig=null;
protectedbooleanignore=true;
publicvoidinit(filterconfigfilterconfig)throwsservletexception{
this.filterconfig=filterconfig;
this.encoding=filterconfig.getinitparameter("encoding");
stringvalue=filterconfig.getinitparameter("ignore");
if(value==null)
this.ignore=true;
elseif(value.equalsignorecase("true"))
this.ignore=true;
else
this.ignore=false;
}
publicvoiddofilter(
servletrequestrequest,servletresponseresponse,filterchainchain)
throwsioexception,servletexception{
//todo自動生成方法存根
if(ignore (request.getcharacterencoding()==null)){
stringencoding=selectencoding(request);
if(encoding!=null)
request.setcharacterencoding(encoding);
}
chain.dofilter(request,response);
}
publicvoiddestroy(){
//todo自動生成方法存根
this.encoding=null;
this.filterconfig=null;
}
protectedstringselectencoding(servletrequestrequest){
return(this.encoding);
}
}
然后再web.xml加上
<!--setcharacterencoding-->
?。糵ilter>
?。糵ilter-name>setcharacterencoding</filter-name>
<filter-class>com.struts.common.setcharacterencodingfilter</filter-class>
?。糹nit-param>
?。紁aram-name>encoding</param-name>
?。紁aram-value>utf-8</param-value>
?。?init-param>
</filter>
?。糵ilter-mapping>
?。糵ilter-name>setcharacterencoding</filter-name>
<url-pattern>/*</url-pattern>
?。?filter-mapping>
<!--setcharacterencoding-->
使用過濾器的好處很多,特別是項(xiàng)目之中。
而且在使用國際化時(shí)就更有用了,只要在頁面指定 <%@ page language="java" pageencoding="utf-8" %>,服務(wù)器就會根據(jù)本地locale來顯示正確的字符集。
所以我特別推薦使用過濾器。
方法三:修改tomcat的server.xml文件中uriencoding
<connectordebug="0"acceptcount="100"connectiontimeout="20000"disableuploadtimeout="true"
port="80"redirectport="8443"enablelookups="false"minsparethreads="25"maxsparethreads="75"
maxthreads="150"maxpostsize="0"uriencoding="gbk">
</connector>
這個(gè)方法主要針對從url中獲取字符串的問題。
在tomcat5.0及以上版本,post和get方法在處理編碼時(shí)有所不同。如果你在url中獲取中文就會出現(xiàn)?號。但在tomcat4.1版本沒有問題,因?yàn)閠omcat4.1的post和get方法在處理編碼時(shí)是一樣的。
新聞熱點(diǎn)
疑難解答
圖片精選