<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    JAVA涂鴉
    關(guān)于JAVA的點點滴滴
    posts - 50,  comments - 689,  trackbacks - 0
        這段時間經(jīng)常看到有人問到web開發(fā)中怎么中文總是?號。原因其實很簡單,因為大家大多用的是tomcat服務(wù)器,而tomcat服務(wù)器的默認編碼為 iso-8859-1(西歐字符)。就是因為iso-8859-1(西歐字符)編碼造成了我們經(jīng)常看到?號。關(guān)于iso-8859-1(西歐字符)更多知 識請看《字節(jié),字符和編碼這篇文章。

    方法一:最簡單也是用的最多的方法。
    <%@ page language="java" pageEncoding="GBK" %>
    或者<%@ page contenttype="text/html;charset=gbk";>這里可以用gb2312或者gbk,只是gbk比gb2312支持跟多的字符。

    這個方法用于jsp頁面中的中文顯示。

    方法二:使用過濾器。
    過濾器使用主要針對表單提交,插入數(shù)據(jù)庫的數(shù)據(jù)都是?號。這也是應(yīng)為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);
    }
    }

    然后再web.xml加上
    <!-- Set Character Encoding-->
    <filter>
    <filter-name>Set Character Encoding</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>Set Character Encoding</filter-name>
    <url-pattern>/*</url-pattern>
    </filter-mapping>
    <!-- Set Character Encoding-->

    使用過濾器的好處很多,特別是項目之中。
    而且在使用國際化時就更有用了,只要在頁面指定<%@ page language="java" pageEncoding="UTF-8" %>,服務(wù)器就會根據(jù)本地Locale來顯示正確的字符集。

    所以我特別推薦使用過濾器。

    方法三:修改tomcat的server.xml文件中URIEncoding。
    <Connector
    debug="0"
    acceptCount="100"
    connectionTimeout="20000"
    disableUploadTimeout="true"
    port="80"
    redirectPort="8443"
    enableLookups="false"
    minSpareThreads="25"
    maxSpareThreads="75"
    maxThreads="150"
    maxPostSize="0"
    URIEncoding="GBK"
    >
    </Connector>
    這個方法主要針對從url中獲取字符串的問題。
    在tomcat5.0及以上版本,post和get方法在處理編碼時有所不同。如果你在url中獲取中文就會出現(xiàn)?號。但在tomcat4.1版本沒有問題,因為tomcat4.1的post和get方法在處理編碼時是一樣的。
    posted on 2006-03-04 10:20 千山鳥飛絕 閱讀(10540) 評論(16)  編輯  收藏 所屬分類: Web開發(fā)

    FeedBack:
    # re: 解決web開發(fā)中的中文問題。
    2006-03-04 10:38 | lucky
    我在項目中(數(shù)據(jù)庫設(shè)置為UTF-8)需要支持國際化,我們就是按照這種三種方式處理的。使用ExtremeCompontes也有人問過編碼問題,本來想這兩天整理出來,沒想到你先做了。謝謝,對于國際化在數(shù)據(jù)庫中的處理:以Mysql為例,設(shè)置為支持utf-8。特別注意:連接數(shù)據(jù)庫的dataurl要如下指定使用utf8編碼,要不然保存、顯示數(shù)據(jù)仍然是"?":
    connectionURL= "jdbc:mysql://localhost:3306/mysqldb?autoReconnect=true&amp;useUnicode=true&amp;characterEncoding=utf-8&amp;mysqlEncoding=utf8"  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-03-05 10:34 | rickhunter
    十分感謝lucky的補充。
    希望大家有什么好的經(jīng)驗都拿出來給大家分享。
      回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-03-23 11:27 | javadolt
    @lucky
    以Mysql為例,設(shè)置為支持utf-8。您好,請問您MySql中數(shù)據(jù)庫的字符集是如何設(shè)置的,謝謝您!我的mysql中只有l(wèi)atin1 big5 czech euc_kr gb2312 gbk latin1_de sjis tis620 ujis 字符集,沒看見UTF-8 :(  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-03-23 14:02 | 千山鳥飛絕
    我沒怎么用過MySQL,但MySQL也支持UTF-8。
    這個不需要你去設(shè)置的。  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-03-25 23:25 | rickhunter
    to javadolt
    你只需要將MySQL設(shè)置為gb2312或者GBK就可以了.  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-03-31 23:42 | FuCheng
    我都是用UTF-8,寫ResourceBundle,用JSTL的fmt標簽,native2ascii轉(zhuǎn)換漢字,一直都挺好的。提交表單的時候都使用UTF-8編碼,服務(wù)器使用URLDecoder從UTF-8解碼出來。  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-04-26 14:01 | ert
    useUnicode=true&amp;characterEncoding=utf-8&amp;mysqlEncoding=utf8
    這個沒有用的。  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-06-28 16:59 | xcx
    我用window.open下載文件,用window.open('../abc/項目文檔.doc');但是提示說/abc/XXX.doc找不到(XXX表示亂碼),如何解決呢?
      回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-07-24 19:09 | jsm
    我采用你的過濾器,怎么時好時壞呀,有時重啟貓后好的,有時重啟后就不好  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-08-11 18:05 | xiaocao
    你好!我用的是你的第二種方法,但是數(shù)據(jù)庫和頁面上顯示均為亂碼,不知道怎么回事?
    我的環(huán)境:struts+hibernate+mysql.
    jndi的連接:jdbc:mysql://localhost:3306/db?user=root&amp;password=mysql&amp;autoReconnect=true&amp;useUnicode=true&amp;characterEncoding=utf-8&amp;mysqlEncoding=utf8
    頁面上<%@ page language="java" pageEncoding="UTF-8"%>
    web.xml有:
    <filter>
    <filter-name>Set Character Encoding</filter-name>
    <filter-class>com.common.strutsbase.SetEncodingFilter</filter-class>
    <init-param>
    <param-name>encoding</param-name>
    <param-value>UTF-8</param-value>
    </init-param>
    </filter>
    <filter-mapping>
    <filter-name>Set Character Encoding</filter-name>
    <servlet-name>/*</servlet-name>
    </filter-mapping>

    能指點一下嗎?謝謝!!  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-08-11 18:15 | xiaocao
    不好意思,web.xml
    <filter>
    <filter-name>Set Character Encoding</filter-name>
    <filter-class>com.forsoft.apportion.common.strutsbase.SetEncodingFilter</filter-class>
    <init-param>
    <param-name>encoding</param-name>
    <param-value>UTF-8</param-value>
    </init-param>
    </filter>
    <filter-mapping>
    <filter-name>Set Character Encoding</filter-name>
    <url-pattern>/*</url-pattern>
    </filter-mapping>

    我在建表的時候已經(jīng)設(shè)置表的編碼為utf-8  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-10-12 08:39 | yiqun
    你好,我發(fā)現(xiàn)在提交表單后,在頁面上顯示的漢字為亂碼,通過ISO-8859-1到UTF-8的轉(zhuǎn)換則可以正常顯示,這是為什么?上面提到的過濾器不是在所有的請求中都強制使用UTF-8來作為編碼的嗎?希望您可以指點一下!  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2006-10-12 09:47 | yiqun
    采用POST方式就可以了!  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2007-05-25 21:31 | jackie.Q
    十分感謝
    我的問題解決了  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2007-06-12 10:22 | frightyouth
    你好,為什么我用MySQL數(shù)據(jù)庫的時候,數(shù)據(jù)庫中的中文是正常的,但查詢到頁面顯示時就是亂碼呢??麻煩您指點一下!!!  回復  更多評論
      
    # re: 解決web開發(fā)中的中文問題。
    2007-06-12 14:22 | 千山鳥飛絕
    @frightyouth
    jdbc:mysql://localhost/BookDB?useUnicode=true&characterEncoding=GBK  回復  更多評論
      
    正在閱讀:



    <2006年3月>
    2627281234
    567891011
    12131415161718
    19202122232425
    2627282930311
    2345678

    常用鏈接

    留言簿(35)

    隨筆檔案

    文章分類

    文章檔案

    好友的blog

    我的其他blog

    老婆的Blog

    搜索

    •  

    積分與排名

    • 積分 - 775249
    • 排名 - 56

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 久久精品女人天堂AV免费观看| 久久精品国产免费观看| 永久免费AV无码网站国产| 久久这里只精品99re免费| av大片在线无码免费| 日韩免费高清一级毛片在线| 亚洲国产精品无码久久九九| 亚洲产国偷V产偷V自拍色戒| 亚洲午夜久久久久久尤物| 国产AV无码专区亚洲AV麻豆丫 | 精品亚洲福利一区二区| www成人免费视频| 免费无码中文字幕A级毛片| 成人免费无码视频在线网站| 免费国产不卡午夜福在线 | 亚洲精品乱码久久久久久自慰| 91精品国产亚洲爽啪在线影院 | av网站免费线看| 亚洲免费视频网站| 女人18一级毛片免费观看| 亚洲精品国精品久久99热| 亚洲黄色在线观看| MM1313亚洲国产精品| 免费一级不卡毛片| 夜夜爽免费888视频| 国产亚洲综合久久系列| 亚洲国产乱码最新视频| 国产99久久久国产精免费| 黄色网址免费观看| 亚洲五月午夜免费在线视频| 亚洲成人网在线观看| 免费观看四虎精品成人| 91嫩草免费国产永久入口| xvideos亚洲永久网址| 亚洲视频手机在线| 午夜成人无码福利免费视频| aⅴ免费在线观看| 亚洲一区二区三区影院| 亚洲一久久久久久久久| 野花香高清视频在线观看免费 | 成人特黄a级毛片免费视频|