session等作用域

作用域分为四种,其中常用的只有两种:
page:页面级作用域,基本用不到
request:请求级作用域,当服务器产生响应时,请求作用域销毁
sessoin:会话级作用域,保证在多次交互过程中,回话作用域始终存在
application:应用级作用域,只要服务器不关闭,一直存在(在Spring框架中会用到这个)

作用域能用小的,尽量用小的,不用大的,可以节约服务器的内存
000000000000分隔符00000000000
这里是session作用域使用主要用到的代码:
存储session:

//session 作用域中存储hehe:lname
			HttpSession session = request.getSession();
			session.setAttribute("hehe",lname);

在网页中调用session存储的 数据:
网页上面写java代码,得到存储的数据:

    <% 
    	String lname1 = (String)request.getAttribute("lname");
   		String lname2 = (String)session.getAttribute("hehe");
    %>

使用<%=lname2 %>得到存储的数据内容:

<body>
	<div>
		来自request作用域的: <%=lname1 %><br>
		来自session作用域的:<%=lname2 %><br>
		<a href="test1.jsp">test1</a>
	</div>
</body>

000000000000分隔符00000000000
今天整理的是session作用域(重点):
原理:在服务器上找一块内存,实际上是一个键值对,前面是 String name,后面是Object value,每一个客户端都有一个session,每个客户端之间,当服务器为客户端下发一个临时的cookie(浏览器的内存中),名字叫JSESSIONID,是一组字母加数字的序列,表示访问服务器session内存的“凭证”,客户端通过JSESSIONID这个凭证访问自己对应的服务器存储session的内存

session失效的情况:
1、客户端关闭浏览器程序,造成了JSESSIONID凭证丢失
2、时效性,session超时(会话超时):a、客户端关闭后,一段时间内没有访问过该session内存,服务器会清理。b、或者一段时间内没有访问过该session内存,服务器会清理。c、回话超时的时间,默认是30分钟,只要发起请求,会话时间从0重新计算
session工作原理图
在这里插入图片描述

000000000000分隔符00000000000
获取session对象:
HttpSession session = request,getSession();
存session:
session.setAttribute(“name”,value);
取session:
Object value = session.getAttribute(“name”);

网页代码如下:

index:

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	请登录:<a href="login.jsp">登录</a>
	注销:<a href="/20181130/LogoffServlet">注销</a>
	<hr>
	<a href="test1,jsp">test1</a>
</body>
</html>

LoginServlet:

package com.neuedu.servlet;

import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
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;

@WebServlet("/LoginServlet")
public class LoginServlet extends HttpServlet {

	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		request.setCharacterEncoding("utf-8");
		response.setCharacterEncoding("tuf-8");
		String lname = request.getParameter("lname");
		String lpass = request.getParameter("lpass");
		request.setAttribute("lname", lname);
		
		if(lname.equals("admin")&&lpass.equals("123"))
		{
			
			//获得rem是否勾选
			String rem = request.getParameter("rem");
			System.out.println(rem);
			if(rem != null)
			{
				//如果rem不等于null,说面选中了记住,存储cookie
				Cookie c1 = new Cookie("uname", lname);
				Cookie c2 = new Cookie("upass", lpass);
				response.addCookie(c1);//向客户端存储cookie
				response.addCookie(c2);//向客户端存储cookie
				c1.setMaxAge(9999);
			}
			
			request.setAttribute("haha", lname);
			
			
			//session 作用域中存储hehe:lname
			HttpSession session = request.getSession();
			session.setAttribute("hehe",lname);
			
			//进行跳转
			request.getRequestDispatcher("/welcome.jsp").forward(request, response);
			
		}
		else{
			//请求重定向
			response.sendRedirect("/login.jsp");
		}
		
	}

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

}

welcome:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
    <% 
    	String lname1 = (String)request.getAttribute("lname");
   		String lname2 = (String)session.getAttribute("hehe");
    %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
	<div>
		来自request作用域的: <%=lname1 %><br>
		来自session作用域的:<%=lname2 %><br>
		<a href="test1.jsp">test1</a>
	</div>
</body>
</html>

test1:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
        <% 
    	String lname1 = (String)request.getAttribute("lname");
   		String lname2 = (String)session.getAttribute("hehe");
    %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
		<a href="test2.jsp">test2</a><br>
			<div>
		来自request作用域的: <%=lname1 %><br>
		来自session作用域的:<%=lname2 %><br>

	</div>
</body>
</html>

test2:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
        <% 
    	String lname1 = (String)request.getAttribute("lname");
   		String lname2 = (String)session.getAttribute("hehe");
    %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
	<div>
		来自request作用域的: <%=lname1 %><br>
		来自session作用域的:<%=lname2 %><br>

	</div>
</body>
</html>

猜你喜欢

转载自blog.csdn.net/ykallan/article/details/84672655