Cookie是存储在客户机的文本文件,它们保存了大量轨迹信息。在servlet技术基础上,JSP显然能够提供对HTTP cookie的支持。
通常有三个步骤来识别回头客:
●服务器脚本发送一系列cookie至浏览器。比如名字,年龄,ID号码等等。
●浏览器在本地机中存储这些信息,以备不时之需。
●当下一次浏览器发送任何请求至服务器时,它会同时将这些cookie信息发送给服务器,然后服务器使用这些信息来识别用户或者干些其它事情。
下面的代码将展示如何使用JSP来设置Cookie:
main.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ page import="java.net.*" %>
<%
//编码,解决中文乱码问题
String str = URLEncoder.encode(request.getParameter("name"),"utf-8");
//设置name和url cookie
Cookie name = new Cookie("name",str);
Cookie url = new Cookie("url",request.getParameter("url"));
//设置cookie的时间
name.setMaxAge(60*60*24);
url.setMaxAge(60*60*24);
//在响应的头部添加cookie
response.addCookie(name);
response.addCookie(url);
%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>获取Cookie</title>
</head>
<body>
<h1>获取到的Cookie</h1>
<ul>
<li><p><b>网站名:</b>
<%= request.getParameter("name")%>
</p></li>
<li><p><b>网址:</b>
<%= request.getParameter("url")%>
</p></li>
</ul>
</body>
</html>
test.html
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Cookie</title>
</head>
<body>
<form action="main.jsp" method=GET>
站点名: <input type="text" name="name">
<br />
网址: <input type="text" name="url" />
<input type="submit" value="提交" />
</form>
</body>
</html>
点击提交就能获取到我们之前所设置的name和url。
下一个例子是关于JSP如何来读取Cookie的:
想要读取cookie,您就需要调用request.getCookies()
方法来获得一个javax.servlet.http.Cookie对象的数组,然后遍历这个数组,使用getName()
方法和getValue()
方法来获取每一个cookie的名称和值。
cookie.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ page import="java.net.*" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>读取Cookie</title>
</head>
<body>
<%
//创建好cookie与cookies
Cookie cookie = null;
Cookie[] cookies = null;
//获取cookies
cookies = request.getCookies();
//判断cookies是否为空
if(cookies != null) {
out.println("<h2>查找Cookie的名与值</h2>");
//通过遍历cookies来一个个地获取我们所需要的cookie
for(int i = 0; i<cookies.length; i++) {
cookie = cookies[i];
out.println("参数名:"+cookie.getName());
out.println("<br>");
out.println("参数值:"+URLDecoder.decode(cookie.getValue(),"utf-8")+"<br>");
out.println("<br>");
}
} else {
out.println("<h2>没有发现Cookie</h2>");
}
%>
</body>
</html>
运行的结果如下:
如何使用JSP删除Cookie:
1、首先要获取一个已经存在的cookie。
2、将cookie的有效期设置为0,使用cookie.setMaxAge()
方法,方法里面的参数为0。
3、将这个cookie重新添加进响应头中。
在原来的获取cookie的代码后面(即cookie = cookies[i]
)加上这几句代码:
if((cookie.getName()).compareTo("name") == 0) {
cookie.setMaxAge(0);
response.addCookie(cookie);
out.println("删除cookie:" + cookie.getName() + "<br>");
}
第一次运行:
第二次运行:
可以看到第二次运行过后我们想要删除的名称为"name"的cookie被成功地给删除了。