用Javascript读取中文COOKIE的解决办法


Posted in Javascript onFebruary 15, 2007

在Cookie的使用中,我们发现这样一个问题:如果写入Cookie的内容是中文(如用户称呼),用服务器端程序(如ASP或PHP)读出完全正确,但是用一般的javascript或VBScript的读Cookie函数取出的却是一堆乱码。这是一个棘手的问题,因为在有些情况下,Cookie的内容需要在客户机端用脚本语言读取。如果你写入了中文,得到了一堆乱码,是不是感觉很别扭呢?解决这个问题,还要从Cookie的存取方式说起。 

我们知道,写入Cookie内容前需要进行escape(十六进制编码),编码时又是以字节为单位的,这就是问题的关键所在:任何一个汉字都会被拆成两个字节分别编码;而在读Cookie时,unescape又以字节单位解码,因此最后每个汉字都变成了两个字节的乱码。怎么办呢?ASP或PHP方式能够正确读出,应该是在unescape解码后,又按照unicode编码把其中的汉字拼了出来。如果这样的话,能不能找到一种变通的方法解决这个问题呢?仔细研究后发现,只要在十六进制codec(编解码)过程中能够保存汉字信息就行了,因而我们需要再外包一层codec过程,方案如下: 

1.在escape编码前,把Cookie字符串中的每个字符转换为unicode码的字符串形式(用一特殊字符作为字串的分隔符)。 

2.在unescape解码后,先把所有unicode字串提取出来,再用对应的函数转换为原字符。 

<SCRIPT LANGUAGE=javascript>   
<!--   
//编码程序:   
function CodeCookie(str)   
{   
 var strRtn="";    for (var i=str.length-1;i>=0;i--)   
 {   

strRtn+=str.charCodeAt(i);   

if (i) strRtn+="a"; //用a作分隔符   
 }   
 return strRtn;   
}   
//解码程序:   
function DecodeCookie(str)   
{   
 var strArr;   
 var strRtn="";   
 strArr=str.split("a");   
 for (var i=strArr.length-1;i>=0;i--)   
 strRtn+=String.fromCharCode(eval(strArr[i]));   
 return strRtn;   
}   
//-->   
</script>  

VBScript版程序如下: 

<SCRIPT LANGUAGE=vbscript>   
<!--   
"编码程序:   
function CodeCookie(str)   
Dim i   
Dim strRtn   for i=len(str) to 1 step -1   
strRtn=strRtn & ascw(mid(str,i,1))   
if (i<>1) then strRtn = strRtn & "a" "用a作分隔符   
next   
CodeCookie=strRtn   
end function   
"解码程序:   
function DecodeCookie(str)   
Dim i   
Dim strArr,strRtn   
strArr=Split(str,"a");   
for i=UBound(strArr)-LBound(strArr) to 1 step -1   
strRtn=strRtn & chrw(Val(strArr(i)))   
next   
DecodeCookie=strRtn   
end function   
-->   
</script>  

例如你要写入的Cookie内容是"一顶abc",经过CodeCookie变为"99a98a97a-31029a26432a"(基于安全考虑,将字符串反转),再经过escape编码后变为"99a98a97a%2D31029a26432a"(escape编码将除字母和数字以外的字符转换为十六进制%XX的形式),注意分隔符不能选%,D和数字。当然,如果有类似密码的重要信息,还需要在加密上再强化一下。因为写入Cookie的一般都是短信息,编码后增加的一些字节可忽略不计。下面的javascript读写Cookie函数中就加入了以上的中文支持。 

function SetCookie(name,value,expires) 

 var exp=new Date(); 
 exp.setTime(exp.getTime()+expires*60*1000); 
 documents.cookie=name+"="+escape(CodeCookie(value))+" ; expires="+exp.toGMTString()+" ; path=/"; 

function GetCookie (name) 

 var strArg=name+"="; 
 var nArgLen=strArg.length; 
 var nCookieLen=documents.cookie.length; 
 var nEnd; 
 var i=0; 
 var j; 

while (i<nCookieLen) 

 j=i+nArgLen; 
 if (documents.cookie.substring(i,j)==strArg) 

 nEnd=documents.cookie.indexOf (";",j); 
 if (nEnd==-1) nEnd=documents.cookie.length; 
 return DecodeCookie(unescape(documents.cookie.substring(j,nEnd))); 

 i=documents.cookie.indexOf(" ",i)+1; 
 if (i==0) break; 

 return null; 

如果用CGI程序写入中文Cookie,客户端读取。如在ASP里,可以先使用前述的编码函数后,再用response写入,例如:response.cookies("Name")=CodeCookie("张三")至此,中文Cookie的问题基本解决。

Javascript 相关文章推荐
在线一元二次方程计算器实例(方程计算器在线计算)
Dec 22 Javascript
跟我学Node.js(四)---Node.js的模块载入方式与机制
Jun 04 Javascript
javascript实现 百度翻译 可折叠的分享按钮列表
Mar 12 Javascript
HTML+CSS+JS实现完美兼容各大浏览器的TABLE固定列
Apr 26 Javascript
Juery解决tablesorter中文排序和字符范围的方法
May 06 Javascript
基于node.js依赖express解析post请求四种数据格式
Feb 13 Javascript
详解webpack+vue-cli项目打包技巧
Jun 17 Javascript
Bootstrap Table从零开始
Jun 30 Javascript
vue-cli 目录结构详细讲解总结
Jan 15 Javascript
Vue和React有哪些区别
Sep 12 Javascript
JavaScript 中判断变量是否为数字的示例代码
Oct 22 Javascript
vue项目中openlayers绘制行政区划
Dec 24 Vue.js
在一个form用一个SUBMIT(或button)分别提交到两个处理表单页面的代码
Feb 15 #Javascript
实例:用 JavaScript 来操作字符串(一些字符串函数)
Feb 15 #Javascript
从Ajax到JQuery Ajax学习
Feb 14 #Javascript
JAVASCRIPT对象及属性
Feb 13 #Javascript
js判断浏览器的比较全的代码
Feb 13 #Javascript
jQuery中文入门指南,翻译加实例,jQuery的起点教程
Feb 09 #Javascript
baidu博客的编辑友情链接的新的层窗口!经典~支持【FF】
Feb 09 #Javascript
You might like
PHP中的按位与和按位或操作示例
2014/01/27 PHP
微信公众平台开发之天气预报功能
2015/08/31 PHP
php遍历解析xml字符串的方法
2016/05/05 PHP
csdn 博客的css样式 v3
2009/02/24 Javascript
一个html5播放视频的video控件只支持android的默认格式mp4和3gp
2014/05/08 Javascript
jQuery实现表格行和列的动态添加与删除方法【测试可用】
2016/08/01 Javascript
网站发布后Bootstrap框架引用woff字体无法正常显示的解决方法
2016/11/24 Javascript
Ionic+AngularJS实现登录和注册带验证功能
2017/02/09 Javascript
一个可复用的vue分页组件
2017/05/15 Javascript
基于JS对象创建常用方式及原理分析
2017/06/28 Javascript
如何实现小程序tab栏下划线动画效果
2019/05/18 Javascript
python k-近邻算法实例分享
2014/06/11 Python
python实现ping的方法
2015/07/06 Python
python装饰器与递归算法详解
2016/02/18 Python
Python生成8位随机字符串的方法分析
2017/12/05 Python
Python+selenium 获取一组元素属性值的实例
2018/06/22 Python
python爬虫框架scrapy实现模拟登录操作示例
2018/08/02 Python
详解Python 切片语法
2019/06/10 Python
pytorch中的上采样以及各种反操作,求逆操作详解
2020/01/03 Python
python_array[0][0]与array[0,0]的区别详解
2020/02/18 Python
用CSS3实现Win8风格的方格导航菜单效果
2013/04/10 HTML / CSS
HTML5 script元素async、defer异步加载使用介绍
2013/08/23 HTML / CSS
加拿大著名时装品牌:SOIA & KYO
2016/08/23 全球购物
莫斯科隐形眼镜网上商店:Linzi
2019/07/22 全球购物
linux面试题参考答案(3)
2012/09/13 面试题
高校毕业生自我鉴定
2013/10/27 职场文书
三好学生自我鉴定
2013/12/17 职场文书
《童年的发现》教学反思
2014/02/14 职场文书
2014年秋季开学典礼主持词
2014/08/02 职场文书
优秀团员事迹材料1500字
2014/08/31 职场文书
2014离婚协议书范文两篇
2014/09/15 职场文书
考察邀请函范文
2015/01/31 职场文书
小学六一主持词开场白
2015/05/28 职场文书
处世之道:关于真诚相待的名言推荐
2019/12/02 职场文书
golang 如何用反射reflect操作结构体
2021/04/28 Golang
Python Pytorch查询图像的特征从集合或数据库中查找图像
2022/04/09 Python