Session概念

Session是用来将数据存储与服务器端的技术

session中保存的是对象

获得Session对象:

HttpSession session = request.getSession();

session会开辟一块区域来区分谁是谁,服务器会为每次会话建立一个sessionId,每个客户会跟一个sessionID对应。并不是关闭浏览器就结束了本次会话,通常是用户执行“退出”操作或者会话超时时才会结束。

session不能区分路径,同一个用户在访问一个网站期间,所有的session在任何一个地方都可以访问到

Session也是一个域对象,Session也是存储数据的区域对象。

session.setAttribute(String name,Object obj);

session.getAttribute(String name);

session.removeAttribute(String name);

package com.oracle.demo01;

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class SessionServlet extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		//获取Session对象
		HttpSession session=request.getSession();
		//向Session域中存储数据
		session.setAttribute("goods","奶瓶");
		//获取JSESSIONID
		String id=session.getId();
		//创建Cookie
		Cookie cookie=new Cookie("JSESSIONID",id);
		cookie.setPath("/WEB08");
		cookie.setMaxAge(60*3);
		//发送Cookie
		response.addCookie(cookie);
		response.getWriter().write("JSESSIONID"+id);
	}

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

 Session对象的生命周期:第一次执行request.getSession()时就会创建

销毁:服务器关闭的时候,session过期30分钟时,从不操作服务器开始计算时间30分钟。

可以在web.xml里面配置

<session-config>

        <session-timeout>30</session-timeout>

</session-config>

手动销毁session

session.invalidate();

作用范围:
默认是在一次会话中,一次会话中任何资源公用一个session对象

 

转载于:https://www.cnblogs.com/awdsjk/p/11145928.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值