一、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]);
}
}
}
%>