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的主要内容,如果未能解决你的问题,请参考以下文章

会话技术

CK2009-ThinkPHP 5.0开发微信小程序商场打通全栈项目架构

第三次作业

百度地图Api详解之地图标注

beego session源码分析

Open Session In View OSIV - 每个请求/线程都会发生这种情况吗?