用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 相关文章推荐
How to Auto Include a Javascript File
Feb 02 Javascript
不间断滚动JS打包类,基本可以实现所有的滚动效果,太强了
Dec 08 Javascript
jQuery之选项卡的简单实现
Feb 28 Javascript
jquery 中的each()跳出循环的语句
May 23 Javascript
jquery+ajax实现注册实时验证实例详解
Dec 08 Javascript
jQuery Validate插件自定义验证规则的方法
Dec 27 Javascript
详解JS去重及字符串奇数位小写转大写
Dec 29 Javascript
JavaScript优化以及前段开发小技巧
Feb 02 Javascript
ReactNative短信验证码倒计时控件的实现代码
Jul 20 Javascript
Javascript中 toFixed四舍六入方法
Aug 21 Javascript
angularJs自定义过滤器实现手机号信息隐藏的方法
Oct 08 Javascript
JS实现多功能计算器
Oct 28 Javascript
在一个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中的reflection反射机制测试例子
2014/08/05 PHP
Yii实现MySQL多数据库和读写分离实例分析
2014/12/03 PHP
php基于表单密码验证与HTTP验证用法实例
2015/01/06 PHP
PHP中strncmp()函数比较两个字符串前2个字符是否相等的方法
2016/01/07 PHP
PHP编写RESTful接口
2016/02/23 PHP
php中的钩子理解及应用实例分析
2019/08/30 PHP
用JAVASCRIPT如何给&amp;lt;textarea&amp;gt;&amp;lt;/textarea&amp;gt;赋值
2007/04/20 Javascript
扩展JS Date对象时间格式化功能的小例子
2013/12/02 Javascript
jQuery插件pagewalkthrough实现引导页效果
2015/07/05 Javascript
详解Bootstrap四种图片样式
2016/01/04 Javascript
Ionic项目中Native Camera的使用方法
2017/06/07 Javascript
AngularJS实现单一页面内设置跳转路由的方法
2017/06/28 Javascript
js 解析 JSON 数据简单示例
2020/04/21 Javascript
swiper实现导航滚动效果
2020/12/13 Javascript
[02:32]DOTA2亚洲邀请赛 VG战队巡礼
2015/02/03 DOTA
[43:36]Liquid vs Mineski 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
python基于xml parse实现解析cdatasection数据
2014/09/30 Python
用python编写第一个IDA插件的实例
2018/05/29 Python
对Python3.6 IDLE常用快捷键介绍
2018/07/16 Python
Django框架模板注入操作示例【变量传递到模板】
2018/12/19 Python
pyqt远程批量执行Linux命令程序的方法
2019/02/14 Python
Python实现性能自动化测试竟然如此简单
2019/07/30 Python
pytorch实现用CNN和LSTM对文本进行分类方式
2020/01/08 Python
python下对hsv颜色空间进行量化操作
2020/06/04 Python
Expedia丹麦:全球领先的旅游网站
2018/03/18 全球购物
linux面试题参考答案(5)
2014/09/01 面试题
企业标语口号
2014/06/10 职场文书
地球一小时宣传标语
2014/06/24 职场文书
平面设计师岗位职责
2014/09/18 职场文书
2014离婚协议书范文(3篇)
2014/11/29 职场文书
2016优秀青年志愿者事迹材料
2016/02/25 职场文书
CSS3 制作的图片滚动效果
2021/04/14 HTML / CSS
html5移动端禁止长按图片保存的实现
2021/04/20 HTML / CSS
Vue中Object.assign清空数据报错的解决方案
2022/03/03 Vue.js
mysql中关键词exists的用法实例详解
2022/06/10 MySQL
阿里云服务器(windows)手动部署FTP站点详细教程
2022/08/05 Servers