cookie、session

本文深入讲解了Cookie和Session的工作原理及应用。详细介绍了服务端如何准备Cookie并发送给客户端,客户端如何获取和使用Cookie,以及Session如何在服务端存储用户信息,实现用户状态的跟踪。同时,探讨了Session的生命周期管理和相关方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

服务端准备Cookie:

response.addCookie(Cookie cookie)

客户端获取cookie:request.getCookies();
不能直接获取某一个单独对象,只能一次性将全部得cookie拿到

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		// TODO Auto-generated method stub
		String username=request.getParameter("username");
		String password=request.getParameter("password");
		User user=us.login(new User(null,username,password,null));
		Cookie cookie = new Cookie("name",username);
		response.addCookie(cookie);
		if(user==null) {
			//response.setContentType("text/html;charset=utf-8")//将cookie传向客户端,在客户端的任意jsp页面都可以调用cookie
	request.getRequestDispatcher("index.jsp").forward(request, response);
		}else {
	response.sendRedirect(request.getContextPath()+"/success.jsp");
		}
	
	}

}
Cookie[] cookies=request.getCookies();
    	for(Cookie cookie :cookies){
    		if(cookie.getName().equals("name")){
    			uname=cookie.getValue();
    		}
    	}

session机制:
客户端第一次请求服务器时,服务端会产生一个sesion对象用于保存该客户的信息,并且每个session对象都会有一个唯一的sessionId;服务端会产生一个cookie,并且该cookie的name=JSESSIONID,value=服务端sessionId的值;
然后服务端会在响应客户端的同时,将该cookie发送给客户端,至此客户端就有了一个存有sessionId的cookie,就可以和服务端的session一一对应
session的几个点:
1、session存储在服务端
2、session是在同一个用户请求时共享
session方法:
String getId():获取sessionId
boolean isNew():判断是否新用户
void invalidate():使session失效
setAttribute()
getAttribute();
void setMaxInactiveInterval(秒):设置最大有效非活动时间,比如超过这个时间就重新登录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值