Session
Posted 离落想AC
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Session相关的知识,希望对你有一定的参考价值。
Session
1、Session存储在服务端。
2、Session 在同一用户请求中是共享的。
3、第一次客户端向服务端发送请求时服务端产生一个sessionid 并复制给cookie 一个Jsession发送给客户端。最终通过Jsession和session相互对应获得请求。
session 机制:
客户端在第一次访问服务端的时候,服务端会产生一个session对象(用于保存该客户的信息) ;
并且每个session对象都会有一个唯一的sessionId( 用于区分其他session) ;
服务端由会产生一个cookie,并且该cookie的name-JSESSIONID , value=服务端sessionId的值;
然后服务端会在响应客户端的同时将该cookie发送给客户端,至此客户端就有了一个cookie (JSESSI0NID) ;
因此,客户端的cookie就可以和服务端的session-对应(JSESSIONID - sessionID)
客户端第二/n次请求服务端时:服务端会先用客户端cookie种的JSESSIONID去服务端的session中匹配sessionid
例子:
客户端:顾客
服务端:存包处
顾客要去存包,第一次去存包,商场判断顾客是否存过包(通过手里是否有钥匙),如果新顾客,那么给你一把新钥匙,一把钥匙对应一个存包箱。如果是老顾客(手里有钥匙),那么直接开箱子。
Session使用方法:
String getId():获取sessionID;
boolean isNew():判断是否是新用户(是否是第一次访问);
void invalidate():使session失效。(退出登录,注销);
void setMaxInactiveInterval(秒):设置最大有效非活动时间;
int setMaxInactiveInterval():获取非活动时间;
使用实例:
login界面:
此界面为登陆界面,主要是包括一个form表格键入用户的用户名和密码。
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<form action = "check.jsp" method = "post">
用户名 <input type = "text" name = "uname"><br/>
密码 <input type = "password" name = "upwd"><br/>
<input type = "submit" value = "登录"><br/>
</form>
</body>
</html>
check界面:
此界面主要功能是获取用户键入的信息,并把信息存放在session存放在cookie中。设置不活动时间10s中后就自动消除。
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<%
request.setCharacterEncoding("utf-8");
String name = request.getParameter("uname");
String pwd = request.getParameter("upwd");
if(name.equals("zs")&&pwd.equals("abc"))
//response.sendRedirect("success.jsp");
//只有登陆成功,session 中才会有uname / upwd
session.setAttribute("uname", name);
session.setAttribute("upwd", pwd);
session.setMaxInactiveInterval(10);
response.sendRedirect("welcome.jsp");
//request.getRequestDispatcher("welcome.jsp").forward(request,response);
else
out.print("用户名或密码有误!");
response.sendRedirect("login.jsp");
%>
</body>
</html>
welcome界面:
此界面是欢迎界面显示欢迎您+用户名。注销按钮,点击注销跳转到invalidate.jsp界面。如果没有用户名则返回login.jsp界面。
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<%
String name = (String)session.getAttribute("uname");
if(name!=(null))
out.print("欢迎你:"+name);
%>
<a href="invalidate.jsp"> 注销</a>
<%
else
response.sendRedirect("login.jsp");
%>
</body>
</html>
invalidate界面:
此界面是注销session的操作。注销完成后,将返回login.jsp界面。
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<%
//全部失效;
//session.invalidate();
//只失效某部分;
session.removeAttribute("upwd");
response.sendRedirect("login.jsp");
%>
</body>
</html>
以上是关于Session的主要内容,如果未能解决你的问题,请参考以下文章