Cookie报错java.lang.IllegalArgumentException

本文介绍了解决使用Cookie存储中文字符时出现的Java.lang.IllegalArgumentException错误的方法。通过使用URLEncoder.encode进行编码并在读取时使用URLDecoder.decode解码,可以有效避免转码问题。
摘要由CSDN通过智能技术生成

项目中做自动登录和保存密码时,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之前把值编码下:

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

取cookie值时解码:
  1. URLDecoder.decode(localCookieValue, "UTF-8"); 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值