隨筆 - 251  文章 - 504  trackbacks - 0
          <2006年11月>
          2930311234
          567891011
          12131415161718
          19202122232425
          262728293012
          3456789

          本博客系個人收集材料及學習記錄之用,各類“大俠”勿擾!

          留言簿(14)

          隨筆分類

          收藏夾

          My Favorite Web Sites

          名Bloger

          非著名Bloger

          搜索

          •  

          積分與排名

          • 積分 - 203415
          • 排名 - 283

          最新評論

          這些天開發(fā)一個項目,服務器是tomcat,操作系統(tǒng)是xp,采用的是MVC架構,模式是采用Facade模式,總是出現(xiàn)亂碼,自己也解決了好多天,同事也幫忙解決,也參考了網上眾多網友的文章和意見,總算是搞定。但是好記性不如爛筆桿,所以特意記下,以防止自己遺忘,同時也給那些遇到同樣問題的人提供一個好的參考途徑:
          (一)????JSP頁面上是中文,但是看的是后是亂碼:
          解決的辦法就是在JSP頁面的編碼的地方<%@?page?language="java"?contentType="text/html;charset=GBK"?%>,因為Jsp轉成Java文件時的編碼問題,默認的話有的服務器是ISO-8859-1,如果一個JSP中直接輸入了中文,Jsp把它當作ISO8859-1來處理是肯定有問題的,這一點,我們可以通過查看Jasper所生成的Java中間文件來確認
          (二)????當用Request對象獲取客戶提交的漢字代碼的時候,會出現(xiàn)亂碼:
          解決的辦法是:要配置一個filter,也就是一個Servelet的過濾器,代碼如下:
          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;
          import?javax.servlet.UnavailableException;

          /**
          ?*?Example?filter?that?sets?the?character?encoding?to?be?used?in?parsing?the
          ?*?incoming?request
          ?*/
          public?class?SetCharacterEncodingFilter?implements?Filter?{

          ????/**
          ?????*?Take?this?filter?out?of?service.
          ?????*/
          ????public?void?destroy()?{
          ????}
          ????/**
          ?????*?Select?and?set?(if?specified)?the?character?encoding?to?be?used?to
          ?????*?interpret?request?parameters?for?this?request.
          ?????*/
          ????public?void?doFilter(ServletRequest?request,?ServletResponse?response,
          ????FilterChain?chain)throws?IOException,?ServletException?{

          ????request.setCharacterEncoding("GBK");

          ????//?傳遞控制到下一個過濾器
          ????chain.doFilter(request,?response);
          ????}

          ????public?void?init(FilterConfig?filterConfig)?throws?ServletException?{
          ????}
          }
          配置web.xml
          <filter>
          <filter-name>Set?Character?Encoding</filter-name>
          <filter-class>SetCharacterEncodingFilter</filter-class>
          </filter>
          <filter-mapping>
          <filter-name>Set?Character?Encoding</filter-name>
          <url-pattern>/*</url-pattern>
          </filter-mapping>
          如果你的還是出現(xiàn)這種情況的話你就往下看看是不是你出現(xiàn)了第四中情況,你的Form提交的數(shù)據(jù)是不是用get提交的,一般來說用post提交的話是沒有問題的,如果是的話,你就看看第四中解決的辦法。
          還有就是對含有漢字字符的信息進行處理,處理的代碼是:
          package?dbJavaBean;

          public?class?CodingConvert
          {???
          ?public?CodingConvert()
          ?{
          ??//
          ?}
          ?public?String?toGb(String?uniStr){
          ?????String?gbStr?=?"";
          ?????if(uniStr?==?null){
          ???uniStr?=?"";
          ?????}
          ?????try{
          ???byte[]?tempByte?=?uniStr.getBytes("ISO8859_1");
          ???gbStr?=?new?String(tempByte,"GB2312");
          ?????}
          ??catch(Exception?ex){
          ????}
          ?????return?gbStr;
          ?}
          ???
          ?public?String?toUni(String?gbStr){
          ?????String?uniStr?=?"";
          ?????if(gbStr?==?null){
          ???gbStr?=?"";
          ?????}
          ?????try{
          ???byte[]?tempByte?=?gbStr.getBytes("GB2312");
          ???uniStr?=?new?String(tempByte,"ISO8859_1");
          ?????}catch(Exception?ex){
          ????}
          ????return?uniStr;
          ?}
          }
          你也可以在直接的轉換,首先你將獲取的字符串用ISO-8859-1進行編碼,然后將這個編碼存放到一個字節(jié)數(shù)組中,然后將這個數(shù)組轉化成字符串對象就可以了,例如:
          String?str=request.getParameter(“girl”);
          Byte?B[]=str.getBytes(“ISO-8859-1”);
          Str=new?String(B);
          通過上述轉換的話,提交的任何信息都能正確的顯示。
          (三)????在Formget請求在服務端用request.?getParameter(“name”)時返回的是亂碼;按tomcat的做法設置Filter也沒有用或者用request.setCharacterEncoding("GBK");也不管用問題是出在處理參數(shù)傳遞的方法上:如果在servlet中用doGet(HttpServletRequest?request,?HttpServletResponse?response)方法進行處理的話前面即使是寫了:
          request.setCharacterEncoding("GBK");
          response.setContentType("text/html;charset=GBK");
          也是不起作用的,返回的中文還是亂碼!!!如果把這個函數(shù)改成doPost(HttpServletRequest?request,?HttpServletResponse?response)一切就OK了。
          同樣,在用兩個JSP頁面處理表單輸入之所以能顯示中文是因為用的是post方法傳遞的,改成get方法依舊不行。
          由此可見在servlet中用doGet()方法或是在JSP中用get方法進行處理要注意。這畢竟涉及到要通過瀏覽器傳遞參數(shù)信息,很有可能引起常用字符集的沖突或是不匹配。
          解決的辦法是:
          1)?打開tomcat的server.xml文件,找到區(qū)塊,加入如下一行:?
          URIEncoding=”GBK”?
          完整的應如下:?
          <Connector?port="8080"?maxThreads="150"?minSpareThreads="25"?maxSpareThreads="75"?enableLookups="false"?redirectPort="8443"?acceptCount="100"?debug="0"?connectionTimeout="20000"?disableUploadTimeout="true"?URIEncoding="GBK"/>?

          2)重啟tomcat,一切OK。
          需要加入的原因大家可以去研究?$TOMCAT_HOME/webapps/tomcat-docs/config/http.html下的這個文件就可以知道原因了。需要注意的是:這個地方如果你要是用UTF-8的時候在傳遞的過程中在Tomcat中也是要出現(xiàn)亂碼的情況,如果不行的話就換別的字符集。

          (四)????JSP頁面上有中文,按鈕上面也有中文,但是通過服務器查看頁面的時候出現(xiàn)亂碼:
          ?????解決的辦法是:首先在JSP文件中不應該直接包含本地化的消息文本,而是應該通過<bean:message>標簽從Resource?Bundle中獲得文本。應該把你的中文文本放到Application.properties文件中,這個文件放在WEB-INF/classes/*下,例如我在頁面里有姓名,年齡兩個label,我首先就是要建一個Application.properties,里面的內容應該是name=”姓名”?age=”年齡”,然后我把這個文件放到WEB-INF/classes/properties/下,接下來根據(jù)Application.properties文件,對他進行編碼轉化,創(chuàng)建一個中文資源文件,假定名字是Application_cn.properties。在JDK中提供了native2ascii命令,他能夠實現(xiàn)字符編碼的轉換。在DOS環(huán)境中找到你放置Application.properties的這個文件的目錄,在DOS環(huán)境中執(zhí)行一下命令,將生成按GBK編碼的中文資源文件Application_cn.properties:native2ascii??encoding?gbk?Application.properties?Application_cn.properties執(zhí)行以上命令以后將生成如下內容的Application_cn.properties文件:name=\u59d3\u540d?age=\u5e74\u9f84,在Struts-config.xml中配置:<message-resources?parameter="properties.Application_cn"/>。到這一步,基本上完成了一大半,接著你就要在JSP頁面上寫<%@?page?language="java"?contentType="text/html;charset=GBK"?%>,到名字的那個label是要寫<bean:message?key=”name”>,這樣的化在頁面上出現(xiàn)的時候就會出現(xiàn)中文的姓名,年齡這個也是一樣,按鈕上漢字的處理也是同樣的。
          (五)????寫入到數(shù)據(jù)庫是亂碼:
          解決的方法:要配置一個filter,也就是一個Servelet的過濾器,代碼如同第二種時候一樣。
          如果你是通過JDBC直接鏈接數(shù)據(jù)庫的時候,配置的代碼如下:jdbc:mysql://localhost:3306/workshopdb?useUnicode=true&characterEncoding=GBK,這樣保證到數(shù)據(jù)庫中的代碼是不是亂碼。
          如果你是通過數(shù)據(jù)源鏈接的化你不能按照這樣的寫法了,首先你就要寫在配置文件中,在tomcat?5.0.19中配置數(shù)據(jù)源的地方是在C:\Tomcat?5.0\conf\Catalina\localhost這個下面,我建立的工程是workshop,放置的目錄是webapp下面,workshop.xml的配置文件如下:
          <!--?insert?this?Context?element?into?server.xml?-->

          <Context?path="/workshop"?docBase="workshop"?debug="0"
          reloadable="true"?>

          ??<Resource?name="jdbc/WorkshopDB"
          ???????????????auth="Container"
          ???????????????type="javax.sql.DataSource"?/>

          ??<ResourceParams?name="jdbc/WorkshopDB">
          ????<parameter>
          ??????<name>factory</name>
          ??????<value>org.apache.commons.dbcp.BasicDataSourceFactory</value>
          ????</parameter>
          ????<parameter>
          ??????<name>maxActive</name>
          ??????<value>100</value>
          ????</parameter>
          ????<parameter>
          ??????<name>maxIdle</name>
          ??????<value>30</value>
          ????</parameter>

          ????
          ????<parameter>
          ??????<name>maxWait</name>
          ??????<value>10000</value>
          ????</parameter>

          ??????<parameter>
          ?????<name>username</name>
          ?????<value>root</value>
          ????</parameter>
          ????<parameter>
          ?????<name>password</name>
          ?????<value></value>
          ????</parameter>

          ????<!--?Class?name?for?mm.mysql?JDBC?driver?-->
          ????<parameter>
          ???????<name>driverClassName</name>
          ???????<value>com.mysql.jdbc.Driver</value>
          </parameter>
          ???<parameter>
          ??????<name>url</name>
          ?<value><![CDATA[jdbc:mysql://localhost:3306/workshopdb?useUnicode=true&characterEncoding=GBK]]></value>
          ????</parameter>
          ??</ResourceParams>

          </Context>
          粗體的地方要特別的注意,和JDBC直接鏈接的時候是有區(qū)別的,如果你是配置正確的化,當你輸入中文的時候到數(shù)據(jù)庫中就是中文了,有一點要注意的是你在顯示數(shù)據(jù)的頁面也是要用<%@?page?language="java"?contentType="text/html;charset=GBK"?%>這行代碼的。需要注意的是有的前臺的人員在寫代碼的是后用Dreamver寫的,寫了一個Form的時候把他改成了一個jsp,這樣有一個地方要注意了,那就是在Dreamver中Action的提交方式是request的,你需要把他該過來,因為在jsp的提交的過程中緊緊就是POST和GET兩種方式,但是這兩種方式提交的代碼在編碼方面還是有很大不同的,這個在后面的地方進行說明。3

          以上就是我在開發(fā)系統(tǒng)中解決中文的問題,不知道能不能解決大家的問題,時間匆忙,沒有及時完善,文筆也不是很好,有些地方估計是詞不達意。大家可以給我意見,希望能共同進步。

          查看原文:http://www.javaresearch.org/article/19240.htm
          posted on 2006-11-21 20:01 matthew 閱讀(205) 評論(0)  編輯  收藏 所屬分類: JavaEE
          主站蜘蛛池模板: 大连市| 山东| 基隆市| 巧家县| 衡阳县| 喜德县| 湘潭县| 民和| 原平市| 龙海市| 阿坝县| 寿阳县| 滕州市| 莱芜市| 潼南县| 桐梓县| 达州市| 惠州市| 宝山区| 沛县| 武乡县| 涞源县| 小金县| 屏南县| 安泽县| 永清县| 通江县| 绥棱县| 普安县| 长汀县| 家居| 江北区| 鸡西市| 青川县| 行唐县| 罗源县| 赤水市| 疏勒县| 大港区| 普陀区| 龙海市|