久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      java中請求亂碼解決方法

      java中請求亂碼解決方法

      出現(xiàn)的問題:

      通過get請求向服務(wù)器發(fā)送請求時,如果請求參數(shù)為中文時,服務(wù)器端接受到的參數(shù)為亂碼。

      亂碼原因分析及解決辦法:

      1、關(guān)于解碼和編碼

      編碼:'中'→1110001

      解碼:1110001→'中'

      亂碼:編碼和解碼過程中使用了不同的字符集

      2、Web應(yīng)用中字符編碼解碼的問題

      (1)請求過程:

      <1>GET請求

      瀏覽器端是以UTF-8進行編碼,所以在服務(wù)器端也應(yīng)該以UTF-8進行解碼

      由于GET請求參數(shù)附著在URL地址后面,所以要統(tǒng)一的URL地址的解碼字符集。

      解決辦法:

      在tomcat配置文件server.xml中找到第一個connector加入如下屬性 URIEncoding=UTF-8

      <2>POST請求

      在獲取請求參數(shù)前執(zhí)行:request.setCharacterEncoding("UTF-8");

      (2)響應(yīng)過程

      (1)指定響應(yīng)數(shù)據(jù)的編碼字符集

      (2)告訴瀏覽器響應(yīng)數(shù)據(jù)應(yīng)該使用什么字符集進行解碼

      <1>Tomcat服務(wù)器會自動根據(jù)“解碼字符集”設(shè)置“編碼字符集”

      <2>設(shè)置編碼字符集:告訴瀏覽器當前響應(yīng)數(shù)據(jù)的內(nèi)容類型:response.setContentType("text/html;charset=UTF-8");需要注意的是,需要在response.getWriter();之前設(shè)置,否則無效。

      建議:

      所有的過濾器都只對POST請求起作用,在jsp頁面中設(shè)置字符編碼方式,都只是對表單提交時的POST請求起作用,對GET請求不能起到設(shè)置其字符編碼的作用,

      在GET請求中使用的是默認的編碼方式,所以對GET請求,需要在server.xml文件中設(shè)置URIEncoding="UTF-8"然后重啟TOMCAT便可以實現(xiàn)解決中文亂碼問題,

      但是不建議在href超鏈接請求中傳達中文參數(shù),也不建議在GET請求中傳遞中文參數(shù)。

      另外對傳遞的部分中文實現(xiàn)傳遞和接收時的統(tǒng)一的編碼方法在傳達參數(shù)時使用

      "reply.jsp?title="+java.net.URLEncoder.encode(keywords)

      然后在接收參數(shù)頁面使用keywords=new String(request.getParameter("keywords").getBytes("8859_1"));這種方式雖然暫時解決了中文亂碼問題,

      但是在后期的維護和部署到其他的服務(wù)器時可以仍會會出現(xiàn)中文亂碼了問題,所以不建議使用。

      對于Post請求,只需在Servlet或者jsp中寫入如下代碼就可以把解決從表單中傳入的中文亂碼問題

       request.setCharacterEncoding("utf-8");

      了解:

      而對于Get請求,因為請求參數(shù)會被附加到地址欄的URL之后,所以不能用上面的處理方法。應(yīng)該這樣:

         String str=request.getQueryString();    //使用URLDecoder解碼字符串    String str1=java.net.URLDecoder.decode(str,"utf-8");    String[] paraStrings=str1.split("&");     //paraStrings[0]就是第一個參數(shù),依次類推...    for(String paraString : paraStrings)    {          String[] nameValue=paraString.split("=");          //nameValue[0]就是表單的name,nameValue[1]就是表單name對應(yīng)的值    }

      還有一種方法就是獲取請求參數(shù)之后對請求參數(shù)值重新編碼,也就是先將其轉(zhuǎn)換成字節(jié)數(shù)組,再將字節(jié)數(shù)組重新解碼成字符串。

        String str=request.getParameter("name");   byte[] bytes=str.getBytes("ISO-8859-1");   String name=new String(bytes,"utf-8");

      結(jié)論:傳遞中文參數(shù)時,最好使用POST請求來提交。不同服務(wù)器設(shè)置編碼方式可能不同,不同操作系統(tǒng)設(shè)置編碼方式也可能不同。

      推薦:java基礎(chǔ)教程

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號