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

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

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

    解決tomcat下中文亂碼問題

    解決tomcat下中文亂碼問題

                                          

    (一) JSP頁面上是中文,但是看的是后是亂碼:
    解決的辦法就是在JSP頁面的編碼的地方<%@ page language="java" contentType="text/html;charset=GBK" %>,因為Jsp轉(zhuǎn)成Java文件時的編碼問題,默認的話有的服務(wù)器是ISO-8859-1,如果一個JSP中直接輸入了中文,Jsp把它當(dāng)作ISO8859-1來處理是肯定有問題的,這一點,我們可以通過查看Jasper所生成的Java中間文件來確認

    (二) 當(dāng)用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;
    }
    }
    你也可以在直接的轉(zhuǎn)換,首先你將獲取的字符串用ISO-8859-1進行編碼,然后將這個編碼存放到一個字節(jié)數(shù)組中,然后將這個數(shù)組轉(zhuǎn)化成字符串對象就可以了,例如:
    String str=request.getParameter(“girl”);
    Byte B[]=str.getBytes(“ISO-8859-1”);
    Str=new String(B);
    通過上述轉(zhuǎn)換的話,提交的任何信息都能正確的顯示。
    (三) 在Formget請求在服務(wù)端用request. getParameter(“name”)時返回的是亂碼;按tomcat的做法設(shè)置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”
    完整的應(yīng)如下:
    <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頁面上有中文,按鈕上面也有中文,但是通過服務(wù)器查看頁面的時候出現(xiàn)亂碼:
    解決的辦法是:首先在JSP文件中不應(yīng)該直接包含本地化的消息文本,而是應(yīng)該通過<bean:message>標(biāo)簽從Resource Bundle中獲得文本。應(yīng)該把你的中文文本放到Application.properties文件中,這個文件放在WEB-INF/classes/*下,例如我在頁面里有姓名,年齡兩個label,我首先就是要建一個Application.properties,里面的內(nèi)容應(yīng)該是name=”姓名” age=”年齡”,然后我把這個文件放到WEB-INF/classes/properties/下,接下來根據(jù)Application.properties文件,對他進行編碼轉(zhuǎn)化,創(chuàng)建一個中文資源文件,假定名字是Application_cn.properties。在JDK中提供了native2ascii命令,他能夠?qū)崿F(xiàn)字符編碼的轉(zhuǎn)換。在DOS環(huán)境中找到你放置Application.properties的這個文件的目錄,在DOS環(huán)境中執(zhí)行一下命令,將生成按GBK編碼的中文資源文件Application_cn.properties:native2ascii ?encoding gbk Application.properties Application_cn.properties執(zhí)行以上命令以后將生成如下內(nèi)容的Application_cn.properties文件:name=u59d3u540d age=u5e74u9f84,在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.0confCatalinalocalhost這個下面,我建立的工程是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ū)別的,如果你是配置正確的化,當(dāng)你輸入中文的時候到數(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)中解決中文的問題,不知道能不能解決大家的問題,時間匆忙,沒有及時完善,文筆也不是很好,有些地方估計是詞不達意。大家可以給我意見,希望能共同進步。

    posted @ 2008-01-07 10:12 魯勝迪 閱讀(430) | 評論 (0)編輯 收藏

    獲取一個數(shù)據(jù)庫的所有表名【DatabaseMetaData】

    <%@ page language="java" import="java.sql.*" %>

    <%
    java.sql.Connection Conn;
    java.sql.Statement Stmt;
    java.sql.ResultSet Rst;
    String con_string="jdbc:mysql://localhost:3306";
    con_string=con_string+"/soft?user=javauser;password=javadude";
    Class.forName("com.mysql.jdbc.Driver");
    Conn = DriverManager.getConnection(con_string);
    //Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
    //String url="jdbc:odbc:lsd";
    //Connection con=DriverManager.getConnection(url);

    DatabaseMetaData dbmd=Conn.getMetaData();
    ResultSet rs=dbmd.getTables(null,null,"%",null);
    //ResultSet rs=dbmd.getTables(null,null,"news",null);

    while(rs.next()){
    out.print("table-name: "+rs.getString(3)+"
    ");
    }

    %>

    上面jsp文件的輸出結(jié)果:
    table-name: admin
    table-name: count_num
    table-name: good
    table-name: jivethreadaddon
    table-name: soft
    table-name: tuijian
    table-name: type
    table-name: type_parent</td> <td width="256" valign="top" class="ArticleTeitle">
    </td> </tr> <tr> <td height="25" colspan="2" valign="top" class="ArticleTeitle">

    posted @ 2007-12-25 12:45 魯勝迪 閱讀(1838) | 評論 (0)編輯 收藏

    servlet中文亂碼解決

    JAVA是Unicode編碼,你得先轉(zhuǎn)換成ISO8859-1,然后再轉(zhuǎn)換成GBK或是GB2312。
    request.setCharacterEncoding("ISO8859-1");
    ad=request.getParameter("name");
    byte[] temp3 = ad.getBytes("GBK");
    String str = new String(temp3);
    這樣就是中文啦!
    還有一種更簡單的方法,就是直接在服務(wù)器里設(shè)置編碼轉(zhuǎn)換。我用的是TOMCAT5.0.28。
    在..\Tomcat 5.0\conf目錄里找到SERVER.XML文件,用寫字板打開它,設(shè)置如下:
    <Connector port="8080" maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
    enableLookups="false" redirectPort="8443" acceptCount="100" debug="0"connectionTimeout="20000" disableUploadTimeout="true" URIEncoding="GBK"/>
    里面增加一個屬性就可以了,URIEncoding="GBK"

    posted @ 2007-12-25 09:58 魯勝迪 閱讀(787) | 評論 (0)編輯 收藏

    解決Oracle XDB與Tomcat等的8080端口的沖突

    方法一:
            從9i開始,oracle的安裝缺省包含了XDB。在數(shù)據(jù)庫后,Oracle XDB的http服務(wù)自動霸占了8080端口,這給使用或JBoss、Tomcat進行java web開發(fā)的人造成了不小的麻煩。
    這里介紹修改XDB的http和ftp服務(wù)端口的3種方法:
     
      1.使用dbms_xdb包修改端口設(shè)置

      使用sys登錄sqlplus
    sqlplus sys/syspassword as sysdba
    然后執(zhí)行如下的腳本
    ============================
    --  Change  the  HTTP/WEBDAV  port  from  8080  to  8081
    call  dbms_xdb.cfg_update(updateXML(
       dbms_xdb.cfg_get()
       ,  '/xdbconfig/sysconfig/protocolconfig/httpconfig/http-port/text()'
       ,  8081))
    /
    --  Change  the  FTP  port  from  2100  to  2111
    call  dbms_xdb.cfg_update(updateXML(
           dbms_xdb.cfg_get()
       ,  '/xdbconfig/sysconfig/protocolconfig/ftpconfig/ftp-port/text()'
       ,  2111))
    /
    COMMIT;
    EXEC  dbms_xdb.cfg_refresh;


      2.使用OEM  console

      選擇數(shù)據(jù)庫,XML  Database,Configuration。更改XDB的有關(guān)設(shè)置。
     
      3.修改SPFILE[SID名].ORA文件,去掉數(shù)據(jù)庫的初始化參數(shù):    

      這個文件是Oracle的啟動配置文件dispatchers='(PROTOCOL=TCP)  (SERVICE=XDB)',將會禁止XDB的http和ftp服務(wù)。

      重啟計算機,或者在服務(wù)中重啟OracleService[SID名]這個服務(wù)。重啟后可能無法使用Enterprise  Manager  Console和其他客戶端連接,這時請使用Oracle的Configuration  and  Migration  Tools/Net  Configuration  Assistant工具刪除監(jiān)聽器,然后新建一個監(jiān)聽器,重啟監(jiān)聽器。


    方法二:
            

    TOMCAT修改端口


    今天啟動oracle后再啟動tomcat時發(fā)現(xiàn)tomcat啟動出錯.百思不得其解..然后關(guān)閉oracle后啟動tomcat后發(fā)現(xiàn)一切正常..原來是這兩個家伙有矛盾..同時看上了8080端口..那事情就好辦拉..
    首先導(dǎo)航到Apache Tomcat 4.0\conf\下..打開server.xml 找到一下代碼部分

    <!-- Define a non-SSL HTTP/1.1 Connector on port 8080 -->
    <Connector className="org.apache.catalina.connector.http.HttpConnector"
    port="8080" minProcessors="5" maxProcessors="75"
    enableLookups="true" redirectPort="8443"
    acceptCount="10" debug="0" connectionTimeout="60000"/>
    <!-- Note : To disable connection timeouts, set connectionTimeout value
    to -1 -->

    將8080端口改為8088或其他未被占用的端口。

    posted @ 2007-12-19 10:14 魯勝迪 閱讀(269) | 評論 (0)編輯 收藏

    僅列出標(biāo)題
    共12頁: First 上一頁 4 5 6 7 8 9 10 11 12 
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    導(dǎo)航

    統(tǒng)計

    常用鏈接

    留言簿(4)

    隨筆分類

    隨筆檔案

    文章分類

    新聞分類

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲欧美日韩综合久久久| 亚洲性69影院在线观看| 精品国产_亚洲人成在线| 啦啦啦www免费视频| 亚洲砖码砖专无区2023 | 国产99久久亚洲综合精品| 免费黄色app网站| 在线观看亚洲网站| 亚洲AV无码一区二区三区国产 | AV无码免费永久在线观看| 亚洲sss综合天堂久久久| 久久久www成人免费毛片| 亚洲av午夜国产精品无码中文字| 在线免费视频一区| 精品在线观看免费| 国产亚洲精品自在久久| 69影院毛片免费观看视频在线| 亚洲av片不卡无码久久| 成年女人免费碰碰视频| 日韩亚洲人成网站| 国产亚洲综合色就色| 69影院毛片免费观看视频在线| 亚洲综合精品成人| 亚洲人成无码网WWW| 久久99精品免费视频| 亚洲av无码一区二区三区天堂古代| 成年18网站免费视频网站| 粉色视频在线观看www免费| 亚洲色成人WWW永久网站| 久久午夜夜伦鲁鲁片免费无码影视| 亚洲精品精华液一区二区 | 亚洲精品永久在线观看| 亚洲国产人成精品| 97公开免费视频| 亚洲爆乳大丰满无码专区| 亚洲国产日韩在线视频| 两性刺激生活片免费视频| caoporn成人免费公开| 亚洲国产成人精品无码一区二区| 全亚洲最新黄色特级网站 | 亚洲尤码不卡AV麻豆|