ASP.NET开发在JavaScript有中文汉字时出现乱码时简单有效的解决方法-阿里云开发者社区

开发者社区> 文艺小青年> 正文

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);


本文转自刚刚博客园博客,原文链接:http://www.cnblogs.com/lijigang/archive/2008/12/12/1354002.html,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
计算机基础2 | 学习笔记
快速学习计算机基础2。
11 0
计算机基础1 | 学习笔记
快速学习计算机基础1。
9 0
数据类型-数值和字符串 | 学习笔记
快速学习数据类型-数值和字符串。
5 0
作用域及作用域链 | 学习笔记
快速学习作用域及作用域链。
5 0
求数组元素的和 | 学习笔记
快速学习求数组元素的和。
6 0
Java classloader详解
Java程序并不是一个可执行文件,而是由很多的Java类组成,其运行是由JVM来控制的。而JVM从内存中查找到类,而真正将类加载进内存的就是ClassLoader,可以说我们每天都在接触ClassLoader,但是很多时候我们没有明白其执行的流程和原理。
8 0
冬季实战营第一期学习报告
通过五天学习与实操,对ECS云服务器入门、快速搭建LAMP环境、部署MySQL数据库、回顾搭建Docker环境和Spring Boot以及使用PolarDB和ECS搭建门户网站操作,对本期学习与实操的认识。
9 0
Redis高可用架构演进
Redis是目前使用最广泛的缓存程序之一,也被应用于多种场景,例如数据缓存、分布式锁等,Redis官方提供了多种部署架构,以满足不同应用场景下对于高可用和扩展性的要求。
9 0
冬季实战营第一期:从零到一上手玩转云服务器实验报告
第一期主要进行了六次实验,分别是《动手实操ECS云服务器》、《动手实操快速搭建LAMP环境》、《使用ECS服务器部署MySQL数据库》、《通过workbench远程登录ECS,快速搭建Docker环境》、《从零搭建Spring Boot的Hello World》以及《使用PolarDB和ECS搭建门户网站》。首先远程登陆ECS实例,搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。然后配置及远程访问MySQL。冯晓帅老师在直播上带大家通过workbench登录ECS并快速搭建Docker环境,运行Spring Boot,最后安装WordPress并搭建博客。
9 0
MySQL高可用架构演进
MySQL是数据库领域当之无愧的霸主之一,其在各行各业被广泛应用,随着广泛使用,对于MySQL本身的高可用性的要求就是不可避免的话题,而MySQL的高可用方案也随着MySQL功能的完善经历了多次升级,本文将对MySQL的各种高可用架构进行分析,以此来了解架构的演进。
11 0
3576
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载