读书人

cookie的容易使用

发布时间: 2012-11-22 00:16:41 作者: rapoo

cookie的简单使用

一、cookie的作用

在我们平常写的B/S程序中,会经常用到cookie,主要有以下一些作用:

1、?记录用户名和密码

以及该用户需要保存的一些信息,如购物购站,使用cookie,可以让用户自动登录到站点等。

2、?定制站点

可以使用cookie来记录用户的偏好。

3、?定向广告

可以使用cookie来记录用记经常访问的主题,并向他们显示与这些主题相关的广告。


二、向客户程序发送cookie

1、?创建cookie对象

Cookie c = new Cookie(“userId”,”landril”);

2、?设置最大时效,默认该cookie是存储在浏览器的内在中,用户关闭浏览器则被删除,下面的方法是将cookie存储在硬盘上。

c.setMaxAge(60*60*24);//一天,如果设置为0则是删除该cookie

3、?将cookie放入到HTTP响应报头,可以使用HttpServletResponse的addCookie方法,此方法不修改之前指定的Set-Cookie报头,而是创建新的报头。

response.addCookie(c);

???????注意:设置cookie的步骤为创建cookie对象,设置最大时效,将cookie放入响应报头,即发送到客户程序,记住一定要将cookie发送到客户程序


三、从客户端读取cookie

1、?调用HttpServletRequest的getCookies得到一个Cookie对象的数组

2、?对数组进行循环,调用cookie的getName方法,获取具体的cookie的值

?

Cookie[] cookies = request.getCookies();if(cookies != null){for(int i=0;i<cookies.length;i++){        Cookie c = cookies[i];        if(“userId”.equals(c.getName())){        System.out.println(c.getValue());}}}
?

?


四、cookie的常用方法

1、?setComment()/getComment():指定或查找与该cookie相关的注释

2、?setDomain()/getDomain():设置或读取该cookie适用的域

3、?setMaxAge()/getMaxAge():操作cookie保留的时间,多长时间后过期

4、?getName():读取cookie的名称

5、?setPath()/getPath():设置或取得cookie适用的路径

cookie.setPath(“/”);指定服务器的所有页面都应该收到该cookie

6、?setSource()/getSource():指定cookie是否只能通过加密连接(SSL)

默认false,表示cookie适用所有连接

7、?setValue()/getValue():指定或获取cookie的值


五、下面给出一个cookie的最简单的使用例子cookie.jsp:

?

<%@ page contentType="text/html; charset=GB2312" import="java.util.*"%><%@ page import="javax.servlet.http.Cookie" %><html><head><title>cookie 用户登录次数</title></head><body><center><font size = 5 color = blue>cookie 用户登录次数</font></center><hr><p></p><%Cookie temp = null;Cookie[] cookies = request.getCookies();int cookielen = 0;if(cookies != null)cookielen = cookies.length;int count=1;//取得cookie变数阵列的长度 if(cookielen != 0) //判断是否成功取得cookie资料{            for (int i = 0; i < cookielen; i++)       {                   temp = cookies[i]; //取得cookies数组中的Cookie变量                                          if (temp.getName().equals("accessCount"))              {                count=Integer.parseInt(temp.getValue());//获取登录页面次数              }       }} %> 通过这个浏览器<font color = blue></font> 您的登录次数是<font color = red>   <%= count %>   </font><br> <%  //下次显示会多一次Cookie accessCount = new Cookie("accessCount", String.valueOf(count+1)); accessCount.setMaxAge(60);//这个只是设置它的生命周期,也就是说,当你设置了这个cookie的有效期为1分钟时,你关了浏览器它不是由浏览器来监视cookie文件夹,发现过期就删除去,而是当用户下去请求该站点时,站点会分析出这个cookie文件内容已过期,就会发一个新的文件内容到客户端,并请求删除或覆盖原来过期的cookie文件,然后浏览器才会执行删除操作,再访问原cookie文件时就找不到了 response.addCookie(accessCount); //将更新后的数据存入cookie变数加入cookie中,存在客户端%></body></html>

?

放入服务器,进行访问时,同时看一下你的浏览器存放cookie文件所在的文件夹,就可以看到访问期时,会产生一个cookie文件,当你不设置setMaxAge时或将它值设置为0时,就不会产生cookie文件,没有设置setMaxAge属性

cookie信息会存放在浏览器中,而设置了setMaxAge属性则会存放在磁盘中。

?

再转:


各位高手,建立的cookies,但是删除的时候失败,想问一下应该怎样做。我在一个test文件夹下的cookies.jsp里建立
了两个cookies,主要代码如下:

?

?

<%Cookie sp=new Cookie("spread",spread);Cookie spn=new Cookie("spreadN",spreadN);sp.setMaxAge(360*24*60*60);spn.setMaxAge(360*24*60*60);sp.setPath("/");spn.setPath("/");response.addCookie(sp);response.addCookie(spn);%>
?

?


然后在同一个目录下用一个logout.jsp文件,想删除cookies,主要代码如下:

?

?

?

<%Cookie sp=new Cookie("spread",null);Cookie spn=new Cookie("spreadN",null);sp.setMaxAge(0);spn.setMaxAge(0);sp.setPath("/");spn.setPath("/");response.addCookie(sp);response.addCookie(spn);%>

?但是删除不了,请求各位帮忙,解决了可加高分。

?

最佳答案

修改logout.jsp文件如下

?

?

<% Cookie[] cookies=request.getCookies(); if(cookies!=null)    {        for(int   i=0;i<cookies.length;i++){     Cookie sp = cookies[i].getName();     if(sp.equals("spreadN"))         {             cookies[i].setMaxAge(0);             response.addCookie(cookies[i]);         }         if(sp.equals("spread"))         {             cookies[i].setMaxAge(0);             response.addCookie(cookies[i]);           }     }    }    %> 
?

?

?

?

?

?

?

?

读书人网 >Web前端

热点推荐