您的位置:首页 > Web前端 > JavaScript

ASP.NET开发在JavaScript有中文汉字时出现乱码时简单有效的解决方法

2008-12-12 20:34 836 查看
一般情况在使用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的方法,请参见转载内容,转载地址:/article/4687184.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 == 0) break;

}

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("您看见我了吗?"));

附:有关此部分的解码可参见如下转载,转载地址:/article/6374547.html

解码:

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

写入时编码

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

说明:以上两点中黄底红字的内容需要特别留意,其他类型编码都转变为Unicode编码,才会被JavaScript的unescape解码。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: