java操作cookie遇到中文会报错的解决方案

本文介绍了一种在项目中使用Cookie保存中文时遇到的问题及解决方案。主要问题是由于中文字符在Base64编码过程中可能出现乱码,导致控制字符错误。解决办法是对中文值使用URLEncoder.encode进行UTF-8编码,并在读取时解码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目当中用到cookie保存中文,但是会报如下错误:

Control character in cookie value, consider BASE64 encoding your value

 

大概意思是保存到cookie当中的值存在控制字符,无法保存。但实际上数据是不存在这种问题的。再看后面的那句话,好像是将要保存的值进行了base64编码,可能是因为中文在编码时出现乱码导致一些控制字符的出现。

 

解决方案:将要保存的值进行URLEncoder.encode(value,"utf-8")编码。

在提取时,同样进行解码:

 

 /**
     * 添加一个cookie值
     * @param name 名称
     * @param value 值
     * @param time  cookie的有效期
     * @param response 保存cookie的对象
     */
     public static void setCookie(String name, String value, Integer time,HttpServletResponse response) {
        try {
            //关键点
            value = URLEncoder.encode(value,"UTF-8");


        } catch (UnsupportedEncodingException e) { }
        Cookie cookie = new Cookie(name, value);
        cookie.setPath("/");
        cookie.setMaxAge(time);
        response.addCookie(cookie);
    }

    /**
     * 根据name值,从cookie当中取值
     *
     * @param name    要获取的name
     * @param request cookie存在的对象
     * @return 与name对应的cookie值
     */
    public static String getCookie(String name, HttpServletRequest request) {
        Cookie[] cs = request.getCookies();
        String value = "";
        if (cs != null) {
            for (Cookie c : cs) {
                if (name.equals(c.getName())) {
                    try {

                   //关键点  
                      value = URLDecoder.decode(c.getValue(),"UTF-8");


                    } catch (UnsupportedEncodingException e) {
                    }
                    return value;
                }
            }
        }
        return value;

    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值