• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            Ajax使用POST提交中文亂碼問題

            Posted on 2009-10-22 20:58 S.l.e!ep.¢% 閱讀(846) 評論(0)  編輯 收藏 引用 所屬分類: HTML
            前段時間寫JSP,使用AJAX以POST方式提交數據,如果是中文字符提交就會亂碼,后來寫ASP時用到AJAX以POST方式提交數據,中文一樣是亂碼。搜索一下相關資料,問題應該是提交數據時是以UTF-8編碼提交,所以接收時如果使用GB2312或者其它中文編碼的話就會亂碼。

            使用GET方式提交數據的時候,中文問題很好解決,setRequestHeader("Content-Type","text/html; encoding=gb18030")就可以了。但這個方法在POST方式中卻不起作用。大家都知道GET方式提交數據有長度限制,有時我們必須使用 POST方式來提交數據。

            對于使用POST,JSP的解決方法如下
            使用escape(或encodeURI,兩個函數都是JavaScript的函數,功能基本相同,可以查一下相關的幫助),但要使用兩次,這個是關鍵。

            初始頁面內容如下(hello.jsp):
            <%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
            <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
            <html>
            <head>
            <title>AJAX提交頁面</title>
            <meta http-equiv="Content-Type" content="text/html; charset=GB18030">
            <script type="text/javascript">
            function justdo(){
            ??? var post = "name=王力猛&email=wallimn@sohu.com&bokee=http://wallimn.bokee.com";
            ??? post = encodeURI(post);
            ??? post = encodeURI(post);??? //兩次,很關鍵
            ??? var xmlObj = new ActiveXObject("Msxml2.XMLHTTP");
            ??? var URL = "act.jsp";??? //文件名需要調整成測試時的相應位置
            ??? xmlObj.open("POST",URL,true);
            ??? xmlObj.setRequestHeader("Cache-Control","no-cache");
            ??? xmlObj.setRequestHeader("Content-Type","application/x-www-form-urlencoded;");
            ??? xmlObj.send(post);??? //注意:POST方式,使用這個來發送內容
            }
            </script>
            </head>
            <body>
            <input type="button" value="提交" onclick="justdo()" />
            </body>
            </html>



            Ajax請求處理頁面(act.jsp)的內容如下:
            <%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>
            <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
            <%@page import="java.net.URLDecoder"%>
            <html>
            <head>
            <title>ajax deal</title>
            <meta http-equiv="pragma" content="no-cache">
            <meta http-equiv="cache-control" content="no-cache">
            <meta http-equiv="expires" content="0">
            </head>
            <body>
            <%
            //遍歷輸出參數內容。
            for (Enumeration e = request.getParameterNames(); e.hasMoreElements();) {
            ??? String h = (String)e.nextElement();
            ??? String v = request.getParameter(h);
            ??? String mm = java.net.URLDecoder.decode(v, "UTF-8");
            ??? System.out.println("請求參數: " + h + " = " + mm);
            }
            %>
            </body>
            </html>


            分析:當調用request.getParameter()函數時,會自動進行一次URI的解碼過程,調用時內置的解碼過程會導致亂碼出現。而URI編碼兩次后,request.getParameter()函數得到的是原信息URI編碼一次的內容。再用可控的解碼函數 java.net.URLDecoder.decode()就可解出原始的正確的信息。


            對于ASP,可以在客戶端使用JavaScript的encodeURIComponent函數(其它編碼函數可能也行,沒有試)編碼兩次,然后ASP使用Request.Form接收后使用JavaScript的decodeURIComponent解碼一次:

            初始頁面內容如下(hello.asp):
            <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
            <html>
            <head>
            <title>AJAX提交頁面</title>
            <meta http-equiv="Content-Type" content="text/html; charset=GB2312">
            <script type="text/javascript">
            function justdo(){
            ??? var post = "name=" +
            encodeURIComponent(encodeURIComponent("王力猛"));??? //兩次
            ??? var xmlObj = new ActiveXObject("Msxml2.XMLHTTP");
            ??? var URL = "act.asp";??? //文件名需要調整成測試時的相應位置
            ??? xmlObj.open("POST",URL,true);
            ??? xmlObj.setRequestHeader("Cache-Control","no-cache");
            ??? xmlObj.setRequestHeader("Content-Type","application/x-www-form-urlencoded;");
            ??? xmlObj.send(post);??? //注意:POST方式,使用這個來發送內容
            }
            </script>
            </head>
            <body>
            <input type="button" value="提交" onclick="justdo()" />
            </body>
            </html>


            Ajax請求處理頁面(act.asp)的內容如下:
            <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
            <html>
            <head>
            <title>ajax deal</title>
            <meta http-equiv="pragma" content="no-cache">
            <meta http-equiv="cache-control" content="no-cache">
            <meta http-equiv="expires" content="0">
            </head>
            <body>
            <%
            Dim context
            context = decodeText(Request.Form("name"))
            Response.Write("name=" & context)
            %>
            </body>
            </html>

            <script language="javascript" runat="server">
            function decodeText(str){
            ??? return (str == null ? "" : decodeURIComponent(str));
            }
            </script>


            ASP處理的原理跟JSP的差不多,都是在客戶端編碼兩次,在服務器端解碼一次。以上方法是我總結網上的方法和自己的研究寫出來的,如果朋友你有更加好的方法請指教。

            (2007-6-30)
            Tag標簽: ASP,AJAX,JSP,POST,亂碼
            国产成人久久精品麻豆一区| 久久伊人五月天论坛| 狠狠色伊人久久精品综合网| 久久久免费精品re6| 国内精品久久久久久久久电影网| 日韩中文久久| 久久婷婷五月综合国产尤物app | 久久精品一本到99热免费| 影音先锋女人AV鲁色资源网久久| 久久久亚洲AV波多野结衣| 精品国产日韩久久亚洲| 久久久久久久波多野结衣高潮| 怡红院日本一道日本久久| 国产精品日韩欧美久久综合| 精品国产青草久久久久福利| 欧美久久天天综合香蕉伊| 午夜精品久久久久9999高清| 久久亚洲熟女cc98cm| 欧美大香线蕉线伊人久久| 国产精品久久久天天影视| 久久久精品免费国产四虎| 久久天天躁狠狠躁夜夜2020| 四虎国产精品免费久久| 色综合久久中文字幕无码| 国产精品一区二区久久精品| 久久国产三级无码一区二区| 婷婷国产天堂久久综合五月| 人妻少妇久久中文字幕 | 成人资源影音先锋久久资源网| 日本精品久久久中文字幕| 日韩久久久久中文字幕人妻| 久久久久亚洲精品无码蜜桃| 91精品日韩人妻无码久久不卡| 亚洲精品乱码久久久久久蜜桃| 亚洲AV无码久久| 久久久亚洲精品蜜桃臀| 午夜欧美精品久久久久久久| 久久精品国产99国产精品| 人妻无码久久一区二区三区免费 | 国色天香久久久久久久小说 | 亚洲国产精品久久久久婷婷老年|