ASP.NET開發在JavaScript有中文漢字時出現亂碼時簡單有效的解決方法

      一般情況在使用ASP.NET開發使用JavaScript有中文漢字時不會出現亂碼情況,比如:alert('您看到我了嗎?');這樣直接輸入中文漢字的代碼中是不會出現亂碼的,如果出現了,一是檢查Web.config文件確保統一編碼形式;二是設置頁面的編碼,如:charset=utf-8等措施,可在網上查詢相關解決方案,這不是本隨筆要闡述的問題。

      本隨筆主要討論,有些時候用JavaScript調用了後臺代碼中傳入的中文漢字會出現亂碼,比如訪問了Cookie中含有中文漢字的情況。我這裏使用的是ASP.NET2.0且全網站的默認編碼是UTF-8,而沒有出現GB2312等其他編碼形式,且Cookie不是在前臺頁面定義賦值的,而是在後臺.cs文件中創建的。下面直接看解決方法:

      1、前臺JavaScript中關鍵解碼代碼。

return unescape(document.cookie.substring(【起始字符序號】, 【結束字符序號】));

附:有關如何用JavaScript訪問Cookie的方法,請參見轉載內容,轉載地址:http://www.cnblogs.com/anderslly/archive/2006/10/11/javascriptcookie.html

問題:
    使得在訪問頁面的時候能夠沿用上次的設置,或者在不同的頁面間共享數據。比如用戶在訪問網站的時候設置了頁面字體的大小,那麼會希望下次訪問的時候仍然能使用同樣的設置進行瀏覽,而不用重複設置。
解決方案:
    在用戶瀏覽頁面並進行設置時,將這些設置保存在cookie中,下次訪問的時候讀取cookie中的設置。
    參考下面的腳本:

    // utility function to retrieve an expiration data in proper format;
    function getExpDate(days, hours, minutes)
    {
        
var expDate = new
 Date();
        
if(typeof(days) == "number" && typeof(hours) == "number" && typeof(hours) == "number"
)
        {
            expDate.setDate(expDate.getDate() 
+
 parseInt(days));
            expDate.setHours(expDate.getHours() 
+
 parseInt(hours));
            expDate.setMinutes(expDate.getMinutes() 
+
 parseInt(minutes));
            
return
 expDate.toGMTString();
        }
    }

    
//utility function called by getCookie()

    function getCookieVal(offset)
    {
        
var endstr = document.cookie.indexOf(";"
, offset);
        
if(endstr == -1
)
        {
            endstr 
=
 document.cookie.length;
        }
        
return
 unescape(document.cookie.substring(offset, endstr));
    }

    
// primary function to retrieve cookie by name

    function getCookie(name)
    {
        
var arg = name + "="
;
        
var alen =
 arg.length;
        
var clen =
 document.cookie.length;
        
var i = 0
;
        
while(i <
 clen)
        {
            
var j = i +
 alen;
            
if (document.cookie.substring(i, j) ==
 arg)
            {
                
return
 getCookieVal(j);
            }
            i 
= document.cookie.indexOf(" ", i) + 1
;
            
if(i == 0break
;
        }
        
return
;
    }

    
// store cookie value with optional details as needed

    function setCookie(name, value, expires, path, domain, secure)
    {
        document.cookie 
= name + "=" + escape(value) +

            ((expires) 
? "; expires=" + expires : ""+
            ((path) 
? "; path=" + path : ""+
            ((domain) 
? "; domain=" + domain : ""+
            ((secure) 
? "; secure" : "");
    }

    
// remove the cookie by setting ancient expiration date

    function deleteCookie(name,path,domain)
    {
        
if
(getCookie(name))
        {
            document.cookie 
= name + "=" +

                ((path) 
? "; path=" + path : ""+
                ((domain) 
? "; domain=" + domain : ""+
                
"; expires=Thu, 01-Jan-70 00:00:01 GMT";
        }
    }


    使用getCookie(name)函數來讀取cookie中保存的值,參數name爲cookie項的名稱。如果該cookie項不存在則返回一個空字符串。
    使用setCookie()函數來保存cookie項的值,其中第一、二兩個參數分別爲cookie項的名稱和值。如果想爲其設置一個過期時間,那麼就需要設置第三個參數,這裏需要通過getExpDate()獲得一個正確格式的參數。
    最後,使用deleteCookie()來刪除一個已存在的cookie項,實際上是通過讓該項過期。
    cookie將數據保存在客戶端。頁面的腳本只能讀取所在域和服務器的cookie值,如果域內有多個服務器,那麼需要設置第五個參數,以指定服務器。瀏覽器的容量一般限定爲每服務器20個name/value對,每個cookie項不超過4000個字符,更現實點,單個cookie項應少於2000字符,也就是說不要用cookie在客戶端保存大容量數據。
    不同的瀏覽器保存cookie的方式也有所不同。IE爲每個域的cookie建立一個文本文件,而Netscape則將所有的cookie存儲在同一個文本文件中。
    注意:cookie存放在客戶端,所以會受到瀏覽器設置的影響,比如用戶可能會禁用cookie。要檢測瀏覽器是否支持cookie,使用屬性navigator.cookieEnabled來判斷。


    參考: (Oreilly) Java Script And Dhtml Cookbook.chm

 

      2、後臺的.cs文件給Cookie值賦中文內容時的代碼

mycookie.Values.Add("cookiename", HttpUtility.UrlEncodeUnicode("您看見我了嗎?"));

附:有關此部分的解碼可參見如下轉載,轉載地址:http://www.cnblogs.com/yzxchoice/archive/2006/08/10/473660.html

解碼:

HttpUtility.UrlDecode(Request.Cookies["flyxnet"].Value 

寫入時編碼

Response.Cookies["flyxnet"].Value = HttpUtility.UrlEncodeUnicode(voteMsg);

說明:以上兩點中黃底紅字的內容需要特別留意,其他類型編碼都轉變爲Unicode編碼,纔會被JavaScript的unescape解碼。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章