现在的位置: 首页 > 综合 > 正文

Cookie报错java.lang.IllegalArgumentException

2013年01月23日 ⁄ 综合 ⁄ 共 560字 ⁄ 字号 评论关闭

项目中做自动登录和保存密码时,Cookie报错java.lang.IllegalArgumentException,上google查了下

在http://hi.baidu.com/xtxycy/blog/item/a614635168c61b14367abe98.html看到了说明:

今天完成了一个用cookie记录用户名的功能,之前没有考虑到用户的用户名如果是中文会是怎样的影响。就在测试的时候,用了一个中文去登陆,发现报错,错误信息如下:

java.lang.IllegalArgumentException: Control character in cookie value, consider BASE64 encoding your value

后来上网查了下,才知道原来是转码的问题,解决方法如下;

J2EE Doc里面的,cookies只支持ASCII字符,而且不能有逗号,分号,
空白。或者以$开头。名字在创建后不能改变。如果要存储中文的,先用URLEcode编码,在存入,取出的时候,用decode解码。。。

在保存cookie之前把值编码下:

URLEncoder.encode(cookieValue, "UTF-8");

取cookie值时解码:

URLDecoder.decode(localCookieValue, "UTF-8");

抱歉!评论已关闭.