java web复习 day07(cookie与session及其应用)

        由于好久没见的室友回来过周末,玩了两天的王者荣耀,上了一小段。学习有点耽搁了,真的要开始减少玩的时间了。

        首先我们先来介绍一下cookie和session的区别:1.Cookie是客户端技术,程序把每个用户的数据以cookie的形式写给用户各自的浏览器。当用户使用浏览器再去访问服务器中的web资源时,就会带着各自的数据去。这样,web资源处理的就是用户各自的数据了。2.Session是服务器端技术,利用这个技术,服务器在运行时可以为每一个用户的浏览器创建一个其独享的session对象,由于session为用户浏览器独享,所以用户在访问服务器的web资源时,可以把各自的数据放在各自的session中,当用户再去访问服务器中的其它web资源时,其它web资源再从用户各自的session中取出数据为用户服务。

一.Cookie的常用api与应用

1.常用API

        response接口也中定义了一个addCookie方法,它用于在其响应头中增加一个相应的Set-Cookie头字段。 同样,request接口中也定义了一个getCookies方法,它用于获取客户端提交的Cookie。

        构造函数:public Cookie(String name,String value);

        设置与得到cookie的值:setValue与getValue方法

        设置与得到cookie的寿命:setMaxAge与getMaxAge方法

        设置与得到cookie的有效路径:setPath与getPath方法

        设置与得到cookie的域名集:setDomain与getDomain方法

        得到cookie名字:getName方法

2.应用

(1)得到上次访问时间
public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		response.setContentType("text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();
		out.write("上次访问的时间是:");
		
		Cookie[] cookies = request.getCookies();
		
		for(int i=0;cookies!=null&&i<cookies.length;i++){
			if(cookies[i].getName().equals("lastAccrssTime")){
				Long time = Long.parseLong(cookies[i].getValue());
				Date date = new Date(time);
				String localDate = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss").format(date);//toLocalString()过时了,改用这个注意月份要大M,分钟用小M
				out.write(localDate);
			}
		}
		
		Cookie cookie = new Cookie("lastAccrssTime", System.currentTimeMillis()+"");
		
		cookie.setMaxAge(1000);//设置有效时间为1000秒
		cookie.setPath("/day07/");//设置仅在/day07才有效
		
		response.addCookie(cookie);
	}

(2)显示用户上次浏览过的商品

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		
		response.setContentType("text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();
		//1.显示本网站所有的书籍
		out.write("本网站有以下书籍:<br/><br/>");
		
		Map<String,Book> books = DB.getAll();
		
		for(Map.Entry<String,Book> me : books.entrySet()){
			Book book = me.getValue();
			out.write("<a href='/day07/servlet/CookieDemo3?id="+book.getId()+"'target='_blank'>"+book.getName()+"</a>");
			out.write("<br/>");
		}
		
		out.write("<br/>");
		//2.显示看过的书籍
		Cookie[] cookies = request.getCookies();
		for(int i=0;cookies!=null&&i<cookies.length;i++){
			if(cookies[i].getName().equals("bookHistory")){
				String[] ids = cookies[i].getValue().split("_");
				for(String id:ids){
					Book book = (Book) DB.getAll().get(id);
					out.write(book.getName() + "<br/>");
				}
			}
		}
		
		
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		
		doGet(request, response);
	}
	
	

}

//模拟数据库
class DB
{
	private static Map<String,Book> map = new LinkedHashMap();
	static{
		map.put("1", new Book("1","javaweb开发","老张","一本好书"));
		map.put("2", new Book("2","spring开发","老黎","一本好书"));
		map.put("3", new Book("3","hibernate开发","老佟","一本好书"));
		map.put("4", new Book("4","struts开发","老毕","一本好书"));
		map.put("5", new Book("5","ajax开发","老张","一本好书"));
	}
	
	public static Map getAll(){
		return map;
	}
	
	
}

//book类
class Book{
	
	private String id;
	private String name;
	private String author;
	private String description;
	
	
	
	public Book() {
		super();
		// TODO Auto-generated constructor stub
	}
	public Book(String id, String name, String author, String description) {
		super();
		this.id = id;
		this.name = name;
		this.author = author;
		this.description = description;
	}
	public String getId() {
		return id;
	}
	public void setId(String id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getAuthor() {
		return author;
	}
	public void setAuthor(String author) {
		this.author = author;
	}
	public String getDescription() {
		return description;
	}
	public void setDescription(String description) {
		this.description = description;
	}
	
	
	
}
public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		response.setContentType("text/html;charset=UTF-8");
		PrintWriter out = response.getWriter();
		
		String bookId = request.getParameter("id");
		Book book = (Book) DB.getAll().get(bookId);
		
		//回送所有书的信息
		out.write("您要查看的书的详细信息如下:<br/><br/>");
		out.write(book.getId() + "<br/>");	
		out.write(book.getName() + "<br/>");
		out.write(book.getAuthor() + "<br/>");
		out.write(book.getDescription() + "<br/>");
		
		//2.给用户回送包含当前商品id的cookie
		String bookHistory = makeHistory(request,bookId);    //  3_2
		Cookie cookie = new Cookie("bookHistory",bookHistory);
		cookie.setMaxAge(1*30*24*3600);	
		response.addCookie(cookie);
	}

	//注意参数
	private String makeHistory(HttpServletRequest request, String bookId) {
		// TODO Auto-generated method stub
		String bookHistory = null;
		Cookie cookies[] = request.getCookies();
		for(int i=0;cookies!=null&&i<cookies.length;i++){
			if(cookies[i].getName().equals("bookHistory")){
				bookHistory = cookies[i].getValue();
			}
		}
		
	        //  bookHistory=null      1    bookHistory=1
		if(bookHistory==null){
			return bookId;
		}
        
                //如果bookHistory不为空,则分为三种情况,分割字符串,放进新集合操作
	        List l = Arrays.asList(bookHistory.split("\\_"));   //[3,4]  //数组  链接使用"\\"的原因是规避_有特殊含义
		LinkedList<String> list = new  LinkedList();
		list.addAll(l);
		
		//书被浏览过,从原来的集合中移除,放到第一位
		if(list.contains(bookId)){
			list.remove(bookId);
			list.addFirst(bookId);
		}else {
                                //如果没有被浏览过,且集合中已有3个(自己设置的最大显示数),移除最后一个放到第一位
                                if(list.size()>=3){
				list.removeLast();
				list.addFirst(bookId);
			}else{
                                //放到第一位就完事了
                                 list.addFirst(bookId);
			}
		}
		
		StringBuffer sb = new StringBuffer();
		for(String lid : list){
			sb.append(lid+"_");
		}
		
		return sb.deleteCharAt(sb.length()-1).toString();

	}

(3)cookie细节(传智视频总结)

1.一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)。
2.一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以存储多个WEB站点提供的Cookie。
3.浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
4.如果创建了一个cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),用户退出浏览器之后即被删除。若希望浏览器将该cookie存储在磁盘上,则需要使用maxAge,并给出一个以秒为单位的时间。将最大时效设为0则是命令浏览器删除该cookie。
5.删除cookie时,path必须一致,否则不会删除


2.Session


在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务。
Session和Cookie的主要区别在于:
Cookie是把用户的数据写给用户的浏览器。
Session技术把用户的数据写到用户独占的session中。
Session对象由服务器创建,开发人员可以调用request对象的getSession方法得到session对象。


禁用Cookie后servlet共享数据导致的问题。
解决方案:URL重写
response. encodeRedirectURL(java.lang.String url)
用于对sendRedirect方法后的url地址进行重写。
response. encodeURL(java.lang.String url)
用于对表单action和超链接的url地址进行重写



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值