1. l Cookie • Cookie 是客户端技术,服务器把每个用户的数据以 cookie 的形式写给用 户各自的浏览器。当用户使用浏览器再去访问服务器中的 web 资源时, 就会带着各自的数据去。这样, web 资源处理的就是用户各自的数据了。 l Session • Session 是服务器端技术,利用这个技术,服务器在运行时可以为每一个 用户的浏览器创建一个其独享的 session 对象,由于 session 为用户浏览 器独享,所以用户在访问服务器的 web 资源时,可以把各自的数据放在 各自的 session 中,当用户再去访问服务器中的其它 web 资源时,其它 web 资源再从用户各自的 session 中取出数据为用户服务。 l Cookie是一种在客户端保持HTTP状态信息的技术,它好比商场发放的优惠卡。 l Cookie是在浏览器访问WEB服务器的某个资源时,由WEB服务器在HTTP响应消 息头中附带传送给浏览器的一片数据,WEB服务器传送给各个客户端浏览器 的数据是可以各不相同的。 l 一旦WEB浏览器保存了某个Cookie,那么它在以后每次访问该WEB服务器时, 都应在HTTP请求头中将这个Cookie回传给WEB服务器。 l WEB服务器通过在HTTP响应消息中增加Set-Cookie响应头字段将Cookie信息 发送给浏览器,浏览器则通过在HTTP请求消息中增加Cookie请求头字段将 Cookie回传给WEB服务器。 l javax.servlet.http.Cookie类用于创建一个Cookie,response接口也中定 义了一个addCookie方法,它用于在其响应头中增加一个相应的Set-Cookie 头字段。 同样,request接口中也定义了一个getCookies方法,它用于获取 客户端提交的Cookie。Cookie类的方法: ü public Cookie(String name,String value) ü setValue与getValue方法 ü setMaxAge与getMaxAge方法 ü setPath与getPath方法 ü setDomain与getDomain方法 ü getName方法 Set-Cookie:username=qiujy;Domain=localhost;path=/ Cookie:username=qiujy;$Path=/jsp_04_servlet
l 一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME) 和设置值(VALUE)。 l 一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以 存储多个WEB站点提供的Cookie。 l 浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个 Cookie的大小限制为4KB。 l 如果创建了一个 cookie ,并将他发送到浏览器,默认情况下它是一个会话级 别的 cookie (即存储在浏览器的内存中),用户退出浏览器之后即被删除。 若希望浏览器将该 cookie 存储在磁盘上,则需要使用 maxAge ,并给出一个 以秒为单位的时间。将最大时效设为 0 则是命令浏览器删除该 cookie 。 l 注意,删除 cookie 时, path 必须一致,否则不会删除
一. 会话
1、概念:用户开一个浏览器,点击多个超链接,访问服务器多个web资源,然后关闭浏览器,整个过程称之为一个会话。
2、保存会话数据的两种技术:Cookie、Session
二、Cookie基本概念:
1、Cookie是客户端技术,服务器把每个用户的数据以cookie的形式写给用户各自的浏览器。当用户使用浏览器再去访问服务器中的web资源时,就会带着各自的数据去。这样,web资源处理的就是用户各自的数据了
2、Cookie是一种在客户端保持HTTP状态信息的技术。
3、Cookie是在浏览器访问WEB服务器的某个资源时,由WEB服务器在HTTP响应消息头中附带传送给浏览器的一片数据,WEB服务器传送给各个客户端浏览器的数据是可以各不相同的。
4、一旦WEB浏览器保存了某个Cookie,那么它在以后每次访问该WEB服务器时,都应在HTTP请求头中将这个Cookie回传给WEB服务器。
5、WEB服务器通过在HTTP响应消息中增加Set-Cookie响应头字段将Cookie信息发送给浏览器,浏览器则通过在HTTP请求消息中增加Cookie请求头字段将Cookie回传给WEB服务器。
6、服务器在客户端保存用户的信息,比如登录名,密码等…就是cookie,这些信息像小甜饼一样,数量并不大,服务器端在需要的时候可以从客户端读取。
7、应用:
(1)保存用户名,密码,在一定时间不用重新登录
(2)记录用户访问网站的喜好(比如有无背景音乐,网页的背景色是什么)
(3)网站的个性化,比如定制网站的服务,内容
8、方法:
javax.servlet.http.Cookie类用于创建一个Cookie,response接口也中定义了一个addCookie方法,它用于在其响应头中增加一个相应的Set-Cookie头字段。 同样,request接口中也定义了一个getCookies方法,它用于获取客户端提交的Cookie。
Cookie类的方法:
public Cookie(String name,String value)
setValue与getValue方法
setMaxAge与getMaxAge方法
setPath与getPath方法
setDomain与getDomain方法
getName方法
举例说明:
1、获取姓名和值得例子:
package com.hbsi.cookie;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class CookieDemo1 extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//response.setContentType("text/html;charset=UTF-8");
//createcookie(response);
PrintWriter out=response.getWriter();
Cookie[] cookies =request.getCookies();
for(int i=0;cookies!=null&&i<cookies.length;i++){
out.print(cookies[i].getValue());
}
}
private void createcookie(HttpServletResponse response) throws IOException {
//处理乱码
response.setContentType("text/html;charset=UTF-8");
PrintWriter out=response.getWriter();
//当客户端访问该servlet时,服务器向客户端写cookie
//1.在服务器端创建一个cookie
Cookie cookie=new Cookie("username","zhangsang");
Cookie cookie1=new Cookie("userpassword","123");
//2.设置cookie的存活时间,如果如设置,cookie不保存
cookie.setMaxAge(7*24*60*60);
cookie1.setMaxAge(7*24*60*60);
//3.将cookie写到客户
response.addCookie(cookie);
response.addCookie(cookie1);
out.print("已经创建了cookie");
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
}
}