java cookie中文乱码_java中cookie存取中文乱码

项目中需要把用户名放入cookie中共享,其中创建cookie代码实现如下:

String userName="李文强";

Cookie cookie = new Cookie("userName", userName);

cookie.setPath("/");

String domain = request.getServerName();

cookie.setDomain(domain);

cookie.setMaxAge(cookieAge);

response.addCookie(cookie);

运行后抛出异常:java.lang.IllegalArgumentException: Control character in cookie value or attribute.

原因是中英文编码不一致造成的。中文采用的是unicode编码,而英文采用的是ASCII编码,所以当COOkie保存中

文的时候需要对中文进行编码,而且从Cookie中取出内容的时候也要进行解码。修改如下:

Cookie cookie = new Cookie("userName", URLEncoder.encode(userName, "UTF-8"));

从cookie中读取用户名:

Cookie[] cookies=request.getCookies();

String clientName="";

try {

for(Cookie cookie:cookies){

if("userName".equals(cookie.getName())){

clientName = URLDecoder.decode(cookie.getValue(),"UTF-8");

}

}

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

删除cookie,只需将cookie的生命周期设置为0即可

Cookie[] cookies=request.getCookies();

try {

for(Cookie cookie:cookies){

if("userName".equals(cookie.getName())){

cookie.setMaxAge(0);

response.addCookie(cookie);

}

}

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

修改cookie,类似于删除cookie的操作,先找到目标cookie然后重新设置它的value值,再返回response。

Cookie[] cookies=request.getCookies();

String clientName="陈晓敏";

try {

for(Cookie cookie:cookies){

if("userName".equals(cookie.getName())){

cookie.setValue(clientName);

response.addCookie(cookie);

}

}

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

应用cookie,首先要掌握它的几个重要属性。下面做一下简单总结。

1.MaxAge

该属性指定cookie的生命周期,以秒为单位。

1)不设置

默认情况下,cookie的值只在浏览器会话期间存在,当用户退出浏览器cookie被清除。

2)正值

正值表示cookie的有效时长,代表的是cookie存在的最大时长。如果希望在下次访问该页面的时候cookie文件仍

然有效,则可以将cookie生命周期设置的稍长一些。

3)负值

负值表示当浏览器关闭时,cookie将会被删除。

4)0值

零值表示删除cookie。

2.Path

正常的cookie只能在一个应用中共享,即一个cookie只能由创建它的应用获得。

在同一台服务器tomcat/webapps下有两个应用projectA和projectB:

1)不设置path属性。

path默认是产生cookie的应用路径,projectA创建的cookie只能在projectA范围内使用,在projectB下获取不到。

2)cookie.setPath("/")

可在同一应用服务器内共享cookie。是相对于应用服务器存放应用的文件夹的根目录而言的,例如tomcat下的

webapps,因此cookie.setPath("/")之后,可以在webapps文件夹下的所有应用共享cookie。

3)cookie.setPath("/projectB/")

此处配置是指projectA设置的cookie只能在projectB应用中使用,即使projectA应用也没有权限。

4)cookie.setPath("/projectB/jsp") 或者cookie.setPath("/projectB/jsp/")

只有在projectB/jsp下可以获得cookie,即使在projectB应用下但是在jsp文件夹外的应用也不能共享。

5)有多条cookie.setPath("xxx")

以最后一条为准。

3.domain

domain可以实现跨域共享。

机器A所在域为tgb.com,包含的应用为projectA。

机器B所在域为dmsd.com,包含的应用为projectB。

1)未设置domain

如果不设置domain属性,默认为创建cookie的网页所在的服务器的主机名。此时projectB是无法共享projectA设

置的cookie的。

2)cookie.setDomain("dmsd.com")

在projectA设置cookie,在projectB和默认的tgb.com下均可cookie共享。

3)输入url访问projectB,必须输入域名才能解析

例如:http://dmsd.com:8080/projectB可以获取projectA设置的cookie,但是在机器B访问本机应用使用

http://localhost:8080/projectB无法获取projectA共享的cookie。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Web开发Cookie是常用的一种状态管理方式,它可以在客户端浏览器和服务器之间传递信息,并且具有跨域的能力。但是在跨域场景下,不同域名之间的Cookie是不能共享的。本文将介绍如何通过Java实现跨域Cookie共享的方法。 一、什么是跨域Cookie共享 在同源策略下,浏览器只允许当前域名下的页面访问该域名下的Cookie,而不允许其他域名的页面访问该域名下的Cookie。这就是所谓的Cookie跨域问题。 但是在实际开发,我们经常需要在不同域名之间共享Cookie。例如,在OA系统,用户登录后可能会跳转到其他子系统,此时需要保持用户登录状态,就需要在不同域名之间共享Cookie。这就是所谓的跨域Cookie共享。 二、实现跨域Cookie共享的方法 在Java,实现跨域Cookie共享的方法有两种: 1、使用第三方Cookie共享方案,例如:CAS、OAuth等。 2、手动实现Cookie共享,即在跨域场景下手动设置Cookie。 下面将介绍手动实现Cookie共享的方法。 三、手动实现Cookie共享 手动实现Cookie共享的原理很简单:在A域名下设置Cookie时,同时在B域名下也设置一个相同名称的Cookie。这样,在B域名下访问时就可以获取到A域名下的Cookie信息了。 具体实现步骤如下: 1、在A域名下设置Cookie时,同时在B域名下也设置一个相同名称的Cookie。 代码示例: ```java // 在A域名下设置Cookie Cookie cookie = new Cookie("userId", "123456"); cookie.setDomain(".domaina.com"); // 设置Cookie的域名为.domaina.com cookie.setPath("/"); // 设置Cookie的路径为根路径 cookie.setMaxAge(60 * 60 * 24 * 7); // 设置Cookie的生命周期为7天 response.addCookie(cookie); // 将Cookie添加到响应 // 在B域名下设置相同名称的Cookie Cookie cookie = new Cookie("userId", "123456"); cookie.setDomain(".domainb.com"); // 设置Cookie的域名为.domainb.com cookie.setPath("/"); // 设置Cookie的路径为根路径 cookie.setMaxAge(60 * 60 * 24 * 7); // 设置Cookie的生命周期为7天 response.addCookie(cookie); // 将Cookie添加到响应 ``` 2、在B域名下访问时,获取A域名下的Cookie信息。 代码示例: ```java // 获取A域名下的Cookie信息 Cookie[] cookies = request.getCookies(); if (cookies != null) { for (Cookie cookie : cookies) { if (cookie.getName().equals("userId")) { String userId = cookie.getValue(); // TODO: 处理业务逻辑 break; } } } ``` 需要注意的是,在设置Cookie时,域名要以点号开头,例如:.domaina.com。这样设置后,所有以domaina.com结尾的子域名都可以共享该Cookie。 四、总结 本文介绍了如何通过Java实现跨域Cookie共享的方法,即手动实现Cookie共享。在跨域场景下,手动实现Cookie共享可以很好地解决Cookie跨域问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值