解決JSP開發(fā)Web程序中文顯示三種方法

字號(hào):


    方法一:最簡(jiǎn)單也是用的最多的方法<%@ page language="java" pageEncoding="GBK" %>
    或者<%@ page contenttype="text/html;charset=gbk";>這里可以用gb2312或者gbk,只是gbk比gb2312支持跟多的字符。
    這個(gè)方法用于jsp頁(yè)面中的中文顯示。
    方法二:使用過濾器
    過濾器使用主要針對(duì)表單提交,插入數(shù)據(jù)庫(kù)的數(shù)據(jù)都是?號(hào)。這也是應(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自動(dòng)生成方法存根 
    if(ignore(request.getCharacterEncoding()==null)){ 
    Stringencoding=selectEncoding(request); 
    if(encoding!=null) 
    request.setCharacterEncoding(encoding); 
    } 
    chain.doFilter(request,response); 
    } 
    publicvoiddestroy(){ 
    //TODO自動(dòng)生成方法存根 
    this.encoding=null; 
    this.filterConfig=null; 
    } 
    protectedStringselectEncoding(ServletRequestrequest){ 
    return(this.encoding); 
    } 
    }
    然后再web.xml加上
    <!--SetCharacterEncoding--> 
    <filter> 
    <filter-name>SetCharacterEncoding</filter-name> 
    <filter-class>com.struts.common.SetCharacterEncodingFilter</filter-class> 
    <init-param> 
    <param-name>encoding</param-name> 
    <param-value>UTF-8</param-value> 
    </init-param> 
    </filter> 
    <filter-mapping> 
    <filter-name>SetCharacterEncoding</filter-name> 
    <url-pattern>/*</url-pattern> 
    </filter-mapping> 
    <!--SetCharacterEncoding-->
    使用過濾器的好處很多,特別是項(xiàng)目之中。
    而且在使用國(guó)際化時(shí)就更有用了,只要在頁(yè)面指定 <%@ page language="java" pageEncoding="UTF-8" %>,服務(wù)器就會(huì)根據(jù)本地Locale來(lái)顯示正確的字符集。
    所以我特別推薦使用過濾器。
    方法三:修改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è)方法主要針對(duì)從url中獲取字符串的問題。
    在tomcat5.0及以上版本,post和get方法在處理編碼時(shí)有所不同。如果你在url中獲取中文就會(huì)出現(xiàn)?號(hào)。但在tomcat4.1版本沒有問題,因?yàn)閠omcat4.1的post和get方法在處理編碼時(shí)是一樣的。