10-29

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 {
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值