Javaweb学习笔记(二)之session,cookie,application

Javaweb学习笔记(二)

cookie(客户端)

什么是cookie
  • “Cookie”是小量信息,由网络服务器发送出来以存储在网络浏览器上,从而下次这位独一无二的访客又回到该网络服务器时,可从该浏览器读回此信息。这是很有用的,让浏览器记住这位访客的特定信息,如上次访问的位置、花费的时间或用户首选项(如样式表)。
Cookie 是个存储在浏览器目录的文本文件,当浏览器运行时,存储在 RAM 中。
一旦你从该网站或网络服务器退出,Cookie 也可存储在计算机的硬驱上。
当访客结束其浏览器对话时,即终止的所有 Cookie。
  • 再次登录,登录时自动填写用户名
//保存cookie是浏览器的动作 如果放在跳转之后 代码是执行的 但是浏览器已经跳转了
		Cookie cookie=new Cookie("cu_name",cu_name);
		cookie.setMaxAge(600) //单位是秒 是cookie的保存的最大时间 时间到了 浏览器跳转
		response.addCookie(cookie);
<%
String cu_name="";
Cookie[] cookies=request.getCookies();
if(cookies!=null&&cookies.length>0){
	for(Cookie c:cookies){
		System.out.println(c.getName());
		if("cu_name".equals(c.getName())){
			System.out.println(c.getValue());
		}
	}
}
%>
  • Cookie在生成时就会被指定一个Expire值,这就是Cookie的生存周期,在这个周期内Cookie有效,超出周期Cookie就会被清除。
<%
//实现登出功能-》 清除cookie后跳转至主页
Cookie c=new Cookie("cu_name","");
c.setMaxAge(0);
response.addCookie(c);
response.sendRedirect("/wen03");
%>

session(服务器)

  • session的工作方式

在这里插入图片描述

1.sessionid是一个会话的key,浏览器第一次访问服务器会在服务器端生成一个session,有一个sessionid和它对应。
2.客户端只保存sessionid到cookie中,而不会保存session,session销毁只能通过invalidate或超时,关掉浏览器并不会关闭session。

Session在何时创建呢?

     在创建了Session的同时,服务器会为该Session生成唯一的Session id,
     而这个Session id在随后的请求中会被用来重新获得已经创建的Session;
     在Session被创建之后,就可以调用Session相关的
     方法往Session中增加内容了,而这些内容只会保存在服务器中,
     发到客户端的只有Session id;当
     客户端再次发送请求的时候,会将这个Session id带上,服务器接受
     到请求之后就会依据Session id找到相应的Session,从而再次使用之.
创建:
  • sessionid第一次产生是在直到某server端程序调用HttpServletRequest.getSession(true)这样的语句时才被创建。
删除:
超时;程序调用HttpSession.invalidate();程序关闭;
session存放在哪里:
 服务器端的内存中。不过session可以通过特殊的方式做持久化管理(memcache,redis)。
session的id是从哪里来的
sessionID是如何使用的:
     当客户端第一次请求session对象时候,服务器会为客户端创建一个session,
     并将通过特殊算法算出一个session的ID,用来标识该session对象
session会因为浏览器的关闭而删除吗?
    不会,session只会通过上面提到的方式去关闭。
什么是session一致性问题?
   只要用户不重启浏览器,每次http短连接请求,理论上服务端都能定位到session,保持会话。

session用法

1.获取session对象:request.getSession();
2.给session设置值:session.setAttribute(“变量名”,值对象);
3.获取session中的值:session.getAttribute(“变量名”);
4.删除session中的值:
session.removeAttribute(“变量名”);
session.invalidate();//删除所有session中保存的键
5.session的removeAttribute和invalidate方法的区别:
removeAttribute()适用于清空指定的属性。
invalidate()是清除当前session的所有相关信息,是让当前浏览器session销毁,

application:

  • 作用于整个服务器的存储数据的地方,一般不到万不得已不使用
application可以用来显示网站的访问客流量
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>主页</title>
<%@ page import="java.util.Random" %>
<%
int count = 1000000;
if(application.getAttribute("count")==null){
	application.setAttribute("count", 1000000);
}else{
	int c = (int)application.getAttribute("count");
	c+=new Random().nextInt(10000);
	count=c;
	application.setAttribute("count", c);
}
%>
</head>
<body>
<h1>欢迎您!您是我们网站的第<%=count %>个访问者</h1>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值