這段時間經常看到有人問到中怎么中文總是?號。原因其實很簡單,因為大家大多用的是tomcat服務器,而tomcat服務器的默認編碼為 iso-8859-1(西歐字符)。就是因為iso-8859-1(西歐字符)編碼造成了我們經??吹??號。
方法一:最簡單也是用的最多的方法。
?。?@ page language="java" pageencoding="gbk" %>
或者<%@ page contenttype="text/html;charset=gbk";>這里可以用gb2312或者gbk,只是gbk比gb2312支持跟多的字符。
這個方法用于jsp頁面中的中文顯示。
方法二:使用過濾器。
過濾器使用主要針對表單提交,插入數據庫的數據都是?號。這也是應為tomcat不按request所指定的編碼進行編碼,還是自作主張的采用默認編碼方式iso-8859-1編碼。
編寫一個setcharacterencodingfilter類。
import java.io.ioexception;
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;
protected filterconfig filterconfig = null;
protected boolean ignore = true;
public void init(filterconfig filterconfig) throws servletexception {
this.filterconfig=filterconfig;
this.encoding=filterconfig.getinitparameter("encoding");
string value=filterconfig.getinitparameter("ignore");
if(value==null)
this.ignore=true;
else if(value.equalsignorecase("true"))
this.ignore=true;
else
this.ignore=false;
}
public void dofilter(servletrequest request, servletresponse response, filterchain chain) throws ioexception, servletexception {
// todo 自動生成方法存根
if (ignore (request.getcharacterencoding() == null)) {
string encoding = selectencoding(request);
if (encoding != null)
request.setcharacterencoding(encoding);
}
chain.dofilter(request, response);
}
public void destroy() {
// todo 自動生成方法存根
this.encoding = null;
this.filterconfig = null;
}
protected string selectencoding(servletrequest request) {
return (this.encoding);
}
}
新聞熱點
疑難解答