用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 相关文章推荐
写的htc的数据表格
Jan 20 Javascript
基于json的jquery地区联动效果代码
Jul 06 Javascript
Javascript的各种节点操作实例演示代码
Jun 27 Javascript
jquery 实现表单验证功能代码(简洁)
Jul 03 Javascript
js判断undefined变量类型使用typeof
Jun 03 Javascript
Node调试工具JSHint的安装及配置教程
May 27 Javascript
javascript面向对象之this关键词用法分析
Jan 13 Javascript
jQuery获取浏览器类型和版本号的方法
Jul 05 Javascript
EsLint入门学习教程
Feb 17 Javascript
javascript对HTML字符转义与反转义
Dec 13 Javascript
jQuery实现ajax的嵌套请求案例分析
Feb 16 jQuery
p5.js绘制创意自画像
Nov 04 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
ThinkPHP 连接Oracle数据库的详细教程[全]
2012/07/16 PHP
php curl的深入解析
2013/06/02 PHP
浅析php中json_encode()和json_decode()
2014/05/25 PHP
php基于str_pad实现卡号不足位数自动补0的方法
2014/11/12 PHP
php目录遍历函数opendir用法实例
2014/11/20 PHP
PHP手机号中间四位用星号*代替显示的实例
2017/06/02 PHP
PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】
2018/05/21 PHP
phpstudy2020搭建站点的实现示例
2020/10/30 PHP
jQuery实现的类flash菜单效果代码
2010/05/17 Javascript
返回页面顶部top按钮通过锚点实现(自写)
2013/08/30 Javascript
node.js中的fs.appendFile方法使用说明
2014/12/17 Javascript
Vue实现双向绑定的方法
2016/12/22 Javascript
AngularJS开发教程之控制器之间的通信方法分析
2016/12/25 Javascript
JavaScript生成指定范围随机数和随机序列的方法
2018/05/05 Javascript
JavaScript事件冒泡与事件捕获实例分析
2018/08/01 Javascript
vue后台管理之动态加载路由的方法
2018/08/13 Javascript
教你搭建按需加载的Vue组件库(小结)
2019/07/29 Javascript
js实现文字头像的生成代码
2020/03/07 Javascript
uni-app使用微信小程序云函数的步骤示例
2020/05/22 Javascript
vue+element UI实现树形表格
2020/12/29 Vue.js
[03:06]3分钟带你回顾DOTA2完美盛典&完美大师赛
2017/12/06 DOTA
python中使用smtplib和email模块发送邮件实例
2014/04/22 Python
Python基础入门之seed()方法的使用
2015/05/15 Python
python 2.7.14安装图文教程
2018/04/08 Python
Python基于TCP实现会聊天的小机器人功能示例
2018/04/09 Python
python读取TXT每行,并存到LIST中的方法
2018/10/26 Python
对Python信号处理模块signal详解
2019/01/09 Python
PyTorch: 梯度下降及反向传播的实例详解
2019/08/20 Python
Python字符串函数strip()原理及用法详解
2020/07/23 Python
远程学习的教学用品和家庭学习资源:Really Good Stuff
2020/04/27 全球购物
英语专业学生的自我评价
2013/12/30 职场文书
单位个人查摆问题及整改措施
2014/10/28 职场文书
2015年化验室工作总结
2015/04/23 职场文书
2016大学生毕业实习心得体会
2016/01/23 职场文书
教你怎么用python实现字符串转日期
2021/05/24 Python
Java Optional<Foo>转换成List<Bar>的实例方法
2021/06/20 Java/Android