Http协议是一种无状态的协议,WEB服务器本身不能识别出哪些请求是同一个浏览器发出来的。
作为web服务器,必须采用一种机制来唯一的标识一个用户,同时记录用户的状态。
在Servlet规范中,常用以下两种机制来完成会话跟踪,(Cookie,Session)
Cookie
第一次访问没有cookie的servlet的服务器的时候,会向服务发送请求,相应报文会设置一个set_cookie传给用户,用户将cookie存储到cookie存储区 ,用户以后每次访问的时候都会带上cookie去访问浏览器 。
- cookie的机制:采用客户端记录http状态信息。
- Cookie是在浏览器访问了WEB服务器的某个资源的时候,由WEB服务器在HTTP响应头中附带传送给浏览器的一个小文本文件。
- 一旦WEB浏览器保存了某个Cookie,那么它在以后每次访问WEB服务器的时候,都会在HTTP请求头中将这个cookie回传给WEB服务器。
练习 : 实现购物车最近浏览记录的功能
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<a href="book.jsp?book=a">a</a><br>
<a href="book.jsp?book=b">b</a><br>
<a href="book.jsp?book=c">c</a><br>
<a href="book.jsp?book=d">d</a><br>
<a href="book.jsp?book=e">e</a><br>
<a href="book.jsp?book=f">f</a><br>
<%
Cookie[] cookies = request.getCookies();
if(cookies!=null && cookies.length>0){
for(Cookie c:cookies){
String cookieName = c.getName();
if(cookieName.startsWith("book_")){
out.println(c.getValue());
out.println("<br>");
}
}
}
%>
</body>
</html>
sevlet做两件事:①确定要删除的书名 ②将传入的书名作为cookie返回
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<%@ page import = "java.util.*" %>
<title>Insert title here</title>
</head>
<body>
book 的名称是
:<%= request.getParameter("book")%>
<a href="books.jsp">return</a>
<%
//这个 Cookie好像是有顺序的按照添加顺序来的
// 确定要删除的Cookie 将Cookie返回给浏览器
String bs_name = request.getParameter("book");
// 确定要删除的cookie
// 当书超过五本时,新添加的book不存在时删除最早的那个cookie,若在其中则删除该cookie
Cookie[] cookies = request.getCookies();
List<Cookie> cookList = new ArrayList<Cookie>();
Cookie temCookie = null;
if(cookies!=null && cookies.length>0){
for(Cookie c:cookies){
String cookieName = c.getName();
if(cookieName.startsWith("book_")){
cookList.add(c);
if(c.getValue().equals(bs_name)){
temCookie = c;
}
}
}
}
// 若从books.jsp页面传入的cook不在list里,则删除最早的那个Cookie
if(cookList.size()>=5 && temCookie==null){
cookList.get(0).setMaxAge(0);
response.addCookie(cookList.get(0));
}
// 若在其中,则删除该cookie , 然后会重新添加这个cookie在最后
if(temCookie!=null){
temCookie.setMaxAge(0);
response.addCookie(temCookie);
}
// 把从book.js页面传入的cookie作为一个Cookie返回
Cookie cookie = new Cookie("book_"+bs_name,bs_name);
response.addCookie(cookie);
%>
</body>
</html>
Cooke的作用范围:可以作用当前目录和当前目录的子目录,但是不能作用于上一级目录。
可以通过setPath的方法来设置Cookie的作用范围,其中/ 代表站点的目录。setCookie(request
.getContextPath())
Cookie的相关方法
服务器向浏览器写入cookie
1.创建一个cookie Cookie cookie = new Cookie(“name”,“value”);
2.setMaxAge() :设置cookie最大生成时效,以秒为单位,若为0,则表示立即删除该cookie。若为负数,表示不存储该cookie,为正数,表示存储时间。
3. setPath() : 设置cookie的作用范围。cookie.setPath(request.getContextPath());
4. addCookie() : 调用response()的方法将cookie传给客户端 ,response.addCookie(cookie)
浏览器从服务器读取cookie
Cookie[] cookies = request.getCookies();
if(cookies!=null && cookies.length>0){
for(Cookie c:cookies){
String cookieName = c.getName();
if(cookieName.startsWith("book_")){
out.println(c.getValue());
out.println("<br>");
}
}
}