Servlet Cookie技术

1、什么是Cookie

浏览器向Web服务器发送请求时,服务器会将少量的数据以set-Cookie消息头的方式发送给浏览器,浏览器将这些数据保存下来;当浏览器再次访问服务器时,会自动将这些数据以Cookie消息头的方式发送给服务器。

2、如何创建Cookie

​ ServletAPI为使用Cookie提供了javax.servlet.http.Cookie

创建Cookie:

Cookie  a  = new Cookie(String name , String value)
response.addCookie( a ) ;
参数说明:
name : 用于区分不同Cookie的名字
value:Cookie的值

3、获取Cookie

获取客户端的所有Cookie对象:
Cookie[] cookies =  request.getCookies();

获取一个Cookie对象的名称或值:

    Cookie[] cookies = request.getCookies();
    Cookie cookie = cookies[0];//得到第一个cookie
    String name = cookie.getName();//cookie名字
    String value = cookie.getValue();//cookie的值

4、如何修改Cookie

步骤1:获取客户端发送的所有Cookie
步骤2:根据name找到要修改的Cookie
步骤3:调用Cookie的 setValue(String newValue)方法修改该Cookie的值

步骤4:将修改后的Cookie加入到response发送回客户端

示例代码:

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    Cookie[] Cookies = request.getCookies();
    if (Cookies != null) {
        for (Cookie c : Cookies) {
            String name = c.getName();
            if (name.equals("city")) {
                c.setValue("李四");
                response.addCookie(c);//同名Cookie会覆盖,以达到修改的目的
            }
        }
    }
}


5、Cookie的生存时间

默认情况下,浏览器会将Cookie保存在内存中,随浏览器窗口的关闭而被删除。
如果希望关闭浏览器后Cookie仍在,可以通过设置过期时间。

语法:
void  Cookie.setMaxAge ( int  seconds ) ;
注:seconds单位是秒,精度不是很高
说明:
seconds> 0 : 浏览器要保存Cookie的最长时间为设置的参数值,如果超过指定的时间,浏览器会删除这个Cookie。此时Cookie保存在硬盘上
seconds= 0 : 删除Cookie。在修改Cookie的生存时间为0后,随着response发送回客户端,替换原有Cookie,因生命周期到了即将该Cookie删除。
seconds< 0 : 缺省(默认)值,浏览器会将Cookie保存到内存中,随浏览器的关闭而被删除。

6、Cookie编码

Cookie只能保存合法的ASCII字符。如果要保存中文,需要将中文转换成合法的ASCII字符,即编码。

Cookie cookie = new Cookie("name", URLEncoder.encode("张三","UTF-8"));

7、Cookie解码

因为中文通过URLEncoder从UTF-8转为 ASCII编码,所以需要用UTF-8从 ASCII编码中 解码出来。
  
注意:Cookie的编码格式和解码格式必须统一才能正确的转码。否则会出现乱码。
  Cookie[] cookies = req.getCookies();
    for (Cookie c : cookies) {
        String value = c.getValue();
        String decode = URLDecoder.decode(value, "UTF-8");//解码
        System.out.println(c.getName()+":"+ decode);
    }

8、Cookie的路径问题

浏览器在访问服务器上的某个地址时,会比较Cookie的路径与该路径是否匹配,只有匹配的Cookie才会发送给服务器
Cookie的默认路径等于添加这个Cookie的Web组件的路径。
例如:

/appName/file/addCookie.jsp添加了一个Cookie,则该Cookie的路径等于/appName/file

浏览器发送Cookie的条件


要访问的地址必须是Cookie的路径或者其子路径时,浏览器才会发送Cookie
例如:

Cookie的路径是 /appName/file,则访问/appName/file/a.jsp 或 /appName/file/b.jsp时会发送Cookie,如果访问 /appName/c.jsp则不会发送Cookie。

如何设置Cookie的路径

使用如下代码段可以设置Cookie的路径:如果有 context 则在addPath必须加上 context路径 

Cookie cookie = new Cookie("name", URLEncoder.encode("张三","UTF-8"));
//只能是localhost:8080[/context]/hello/*  才会发送Cookie
cookie.setPath("[/context]/hello");
//cookie.setPath("/");//Web工程的任意路径,localhost:8080[/context]/*  都发送Cookie
resp.addCookie(cookie);//添加Cookie

9、Cookie的局限性

Cookie可以被用户禁止
Cookie会将状态保存在浏览器端,不安全。对于敏感数据,需要加密后再使用Cookie来保存
Cookie只能保存少量的数据,大约4kb左右
Cookie的个数是有限制的

Cookie只能保存字符串



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值