cookie包含中文导致的问题

周五项目测试完毕没问题之后上线,上线之后发现有的账户登录不上

原因为,用来记录追踪用户的cookie中包含cookie。读取,写入时候发生异常。

异常大概是这个样子:

java.lang.IllegalArgumentException: Control character in cookie value or attribute.
        at org.apache.tomcat.util.http.CookieSupport.isHttpSeparator(CookieSupport.java:193)
        at org.apache.tomcat.util.http.CookieSupport.isHttpToken(CookieSupport.java:217)
        at org.apache.tomcat.util.http.ServerCookie.appendCookieValue(ServerCookie.java:186)
        at org.apache.catalina.connector..Response.generateCookieString(Response.java:1032)
        at org.apache.catalina.connector..Response.addCookie(Response.java:974)
        at org.apache.catalina.connector..ResponseFacade.addCookie(ResponseFacade.java:381)
        at com.vcfilm.interceptor.service.AutologonService.setCookie(AutologonService.java:168)
        at com.vcfilm.interceptor.service.AutologonService.saveLogonInfo(AutologonService.java:129)
        at com.vcfilm.interceptor.service.AutologonService.saveLogonInfo(AutologonService.java:139)
        at com.vcfilm.wechat.actioncommon.BaseAction.SaveSession(BaseAction.java:45)
        at com.vcfilm.wechat.actioncommon.BaseAction.SetMember(BaseAction.java:191)
        at com.vcfilm.wechat.member.MemberAction.logincheck(MemberAction.java:364)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:601)

中文需要 URLEncoder.encode.  utf-8

可参这篇文章 http://blog.csdn.net/newyear1988/article/details/7817066

加了之后发现还是有问题,写cookie的时候用des加密了,发现取cookie,getVal()之后用解密的时候异常,于是在捕获异常代码块直接返回了getVal()得到的值。

    /**
     * 从cookie中取值
     * */
    public String getCookieVal(HttpServletRequest request, String key){
        Cookie[] cookies= request.getCookies();
        if(null != cookies && cookies.length > 0){
            for(Cookie c:cookies){
                if(c.getName().equalsIgnoreCase(key)){
                    if(null != c){
                        try{
                            return URLDecoder.decode(c.getValue(), "utf-8");
                        }catch(Exception e){
                            e.printStackTrace();
                            return c.getValue();
                        }
                    }
                }
            }
        }
        return "";
    }

    /**
     * 保存值到cookie
     * */
    public void setCookie(String key, String val, int maxAge){
        try{
            val = URLEncoder.encode(val, "utf-8");
        }catch(Exception e){
            e.printStackTrace();
        }
        Cookie cookie = new Cookie(key, val);
        if(maxAge > 0){
            cookie.setMaxAge(maxAge);
        }
        cookie.setPath("/");
        ServletActionContext.getResponse().addCookie(cookie);
    }
时间: 2024-10-05 17:53:41

cookie包含中文导致的问题的相关文章

Control character in cookie value, consider BASE64 encoding your value , java操作cookie遇到中文会报错的解决方案

项目当中用到cookie保存中文,但是会报如下错误: Control character in cookie value, consider BASE64 encoding your value 大概意思是保存到cookie当中的值存在控制字符,无法保存.但实际上数据是不存在这种问题的.再看后面的那句话,好像是将要保存的值进行了base64编码,可能是因为中文在编码时出现乱码导致一些控制字符的出现.看来setCookie方法不支持保存中文(GBK)编码的样子. 解决方案:将要保存的值进行URLE

sublime text2 打开包含中文的文件会自动追加.dump后缀解决办法

用sublime text2 打开.c, .h,.txt等文件会自动追加一个.dump后缀,這样在打开.c,.h等文件时无法正常识别,从而无法正常进行语法着色,网上说是因为安装了GBK Encoding Support 插件的问题,于是就删除这个插件,发现再打开不会自动加.dump后缀了,但是遇到中文就乱码了, 因为GBK-.,这个插件就是解决中文乱码用的,那怎么办呢? 其实只要重新保存一下就可以了,比如我打开一个A.h文件,这个里有中文注释, 第一次打开时因为有中文所以sublime text

ORACLE判别字段是否包含中文

在ORACLE数据库中如何查找那些字段里面包含中文的数据记录呢,有时候就是有这样的特殊需求,下面整理了一些判别字段中包含中文记录的几个方法 1:使用ASCIISTR函数判别 ASCIISTR函数说明: ASCIISTR返回字符的ASCII形式的字符串.非ASCII的字符被转化为\xxxx的形式. 使用ASCIISTR函数也是根据非ASCII字符会被转化这个特性来判别中文字符,只要里面包含中文字符,则必定会有\xxx这样的字符.且简体汉字的编码范围是B0A1 - F7FE.如下例子所示 CREAT

ElKstack-解决nginx日志url链接包含中文logstash报错问题

logstash报错现象 Trouble parsing json {:source=>"message", :raw=>"{\"@timestamp\":\"2016-05-30T14:51:27+08:00\",\"host\":\"10.139.48.166\",\"clientip\":\"180.109.110.203\",\"

php 判断字符串是否包含中文

正则表达式: /[\x7f-\xff]/ 如: var_dump(preg_match("/[\x7f-\xff]/",'Hello 你好')); 那么它会返回true,因为字符串中包含中文

jsp get方式请求参数中包含中文乱码问题解决

1. 自己接收到参数之后在后台进行转码处理 2: 修改tomcat的配置文件  server.xml <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="utf-8"/> 即可 jsp get方式请求参数中包含中文乱码问题解决,布布扣,bubuk

vb.net中,如何把byte array还原成为包含中文的字符串

这个问题,在网上好找了半天,但说实在话,不得不说,现在的程序员,脑子都僵化了. 一个能解决的也没有. 这还不说,多数人指出应当两边都用UNICODE,不要用ASC 2码之类的.我想说,这些是人家问的吗?不懂就是不懂,要是我就这样,何必不懂还要瞎JB指挥? 但我要说,这正是知其然不知其所以然,正确的回答,永远是先解释完提出问题的人,然后解决之. 然后,如果你愿意画蛇添足,再加上自己的想法.不想多说了,正确的代码我放在这里: '====================================

字符串是否包含中文

/** * 是否包含中文 **/ public static boolean isContainsChinese(String str) { String regEx = "[\u4e00-\u9fa5]"; Pattern pat = Pattern.compile(regEx); Matcher matcher = pat.matcher(str); boolean flg = false; if (matcher.find()) { flg = true; } return fl

实现textarea限制输入字数(包含中文只能输入10个,全ASCII码能够输入20个)

textarea称文本域,又称文本区,即有滚动条的多行文本输入控件,在网页的提交表单中经常用到.与单行文本框text控件不同,它不能通过maxlength属性来限制字数,为此必须寻求其他方法来加以限制以达到预设的需求. 通常的做法就是使用#脚本语言来实现对textarea文本域的字数输入限制,简单而实用.假设我们有一个id为 txta1 的textarea文本区,我们可以通过以下代码限制它的键盘输入字数为10个字(汉字或其他小角字符): <script language="#"