Cookie报错java.lang.IllegalArgumentException

用cookie做记录上次登录时间时,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之前把值编码下:

[java]  view plain copy
  1. URLEncoder.encode(cookieValue, "UTF-8");  

取cookie值时解码:

[java]  view plain copy
  1. URLDecoder.decode(localCookieValue, "UTF-8")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值