js與ASP.NET 中文亂碼問題

來源:互聯網
上載者:User

1. 用戶端 -> 服務端的問題
1.1. get 方式提交短資料效率比 post 方式高
原因:個人感覺
1.2. post 方式提交時,若資料中含有中文,則服務端獲得的資料中文部分會變為亂碼
原因:  可能是提交時 XMLHttpRequest 自動對非標準 ASCII 字元進行了編碼。
     可能只是簡單的逸碼轉換,但具體編碼方式不詳, 在服務端就很難還原。
解決:(a) 在用戶端提交前,對串中的非標準 ASCII 字元用 escape() 手動轉碼。
     這種方法對非標碼位置比較有規律(比如存放在不同的變數中)的情況比較合適。
     在服務端擷取後無須用 unescape() 轉換即可正常處理。
   (b) 對非標碼多而不方便分別 escape() 的,可以用 encodeURI() 兩次(是兩次,不是一次)。
     服務端擷取後用 decodeURI() 一次即得到原正確內容。
疑惑:
     以上兩個解決方案經測試都正確可行。
     有個疑惑就是,瀏覽器在提交資料的時候,看起來是對非標碼進行了一次轉換,
     而在服務端擷取時(如 Request(), getAttribute() 等),看起來又偷偷進行了一次逆向轉換。
     而這兩次轉換似乎沒有遵循同樣的標準,從而對非標碼的預設轉換會導致取不到正確的內容。
     而在用戶端 escape() 後,服務端的逆轉換結果就是正確的。可惜 escape() 會對串中的所有可轉換
     字元都進行轉換,而標準 ASCII 碼轉換後,在服務端取出來又成了錯的了(神奇....)。
     所以 escape() 僅適合用來轉非標碼。
     終極解決方案就是,在用戶端進行連續的兩次 encodeURI()。
     這個規律是從分析服務端轉碼後的結果串得到的。
     比如‘中'字,在 encodeURI() 一次後被轉碼為‘%E4%B8%AD',而在服務端手動進行一次
     decodeURI() 卻得到了亂碼,猜想會不會是 Request() 偷偷進行那一次轉碼把不該轉的重要標誌
     ‘%'也轉掉了,於是在用戶端多做一次 encodeURI(),此時‘中'字的轉碼結果就成了
     ‘%25E4%25B8%25AD',25h 恰好便是‘%',這樣一來,服務端偷轉一次,把‘%25'解為
     ‘%',再由手動 decodeURI() 轉的時候,串已經變成了‘%E4%B8%AD',這樣就得到了正確的
     內容。
     好像沒有說清楚,不過我是明白了,希望以後忘掉的時候也能再看懂。
2. 服務端 -> 用戶端的問題
2.1. 迴轉含有中文的資料時,用戶端收到的是亂碼
原因:  肯定是頁面編碼的問題,因為我的前提就是不強求使用統一的編碼,所以這個問題要解決。
解決:  太簡單,只需要在服務端向用戶端回寫資料前任何地方設定 Response.Chartset = "gb2312" 即可,
     不需要像很多討論到的要轉碼甚至有人寫出大段的轉碼程式,當然,用戶端如果是別的編碼方式,
     改一下就行了。
2.2. 用戶端用 JSON 方式處理接收資料時,eval() 函數不能正確地把收到的資料解釋為程式碼片段
     比如用 var obj = eval( "{ p1:1, p2:2 }" ) 這樣的形式,obj 是不能正確被初始化為對象執行個體的,而是會
     收到一個缺少分號的錯誤,而用 eval( "var obj = { p1:1, p2:2 }" ) 這樣的形式,就能正確地產生一個
     obj 的有效對象執行個體。
     其實仔細想一下,似乎也對,eval() 並不是如書上所講,直接把串作為代碼的一部分插入到整個代碼
     段中,而是返迴轉入的運算式的值,而以‘{...}'的形式定義的空函數對象,其運算式值本身是
     undefined,而若其中成員多於一個,則此表達值根本不能作為合法文法獨立存在,所以才會報錯;
     而後一種形式,其實質其實是一個賦值運算式,雖然首碼了 var 會導致整個運算式值為 undefined,
     但此過程中卻真實地產生了 obj 對象執行個體。在之後的上下文中引用 obj 就是有效了。
     經過實驗看來,書上和部分前輩文章提到的第一種用法,其實是不能正確工作的,至少在我的機器
     上,它確實失敗了。當然,不能不考慮有可能是我的瀏覽器甚至是 OS 本身的原因,這個就深了。
     解決:不管有多深,問題總是要解決的。也很簡單,只需要按第二種形式,把接收變數的定義一起放
     到 eval() 中,即可正常工作。
     另外,迴轉 JSON 資料時,也要考慮B/S雙方編碼問題,如果不一致,按 2.2 中的方法即可解決。
     很重要的一點是,有時候 debug 或 trace 出來的結果,特別是字串,看起來確實是正確的,但就
     是不能正常工作,那時候就需要從編碼的層次去驗證,而不要僅僅考慮代碼本身邏輯的問題。因為有
     些非列印編碼,在 debug 和 trace 時都是不會被回顯到螢幕上的。“眼見非實”,這一點,在任何
     地方永遠適用。
綜合感受
     Ajax 作為一種技術,其本身並無先進之處,相反過多地依賴和信仰會令其成為開發中的累贅,大量
     的精力耗費在基礎工作中,思路游離於商務邏輯之外,這是一件好事,可以令你的工作更快地以失敗
     告終。
     但,Ajax 作為一種思想,反而是值得推崇的,這種思想,早已經由賣童裝的美特斯邦威作出了精闢
     的概括——不走尋常路。
     數年來,在世界各地,
     有 80% 的開發人員沒有想到在 submit 之外去找路,他們是幸福的,他們走在一條熟悉的路上。
     另外 10% 的人走在了 iframe 的路上,他們是幸運的,他們找到了一條風景更加美好的路。
     另外 8% 的人在草叢中發現了 XMLHttpRequest,他們是值得尊敬的,他們替人們找到了新的路。
     另外 2% 的人把這條新路命名為 Ajax,他們是偉大的,他們替人們找到了加班到累死的理由。
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.