The session object is used to record the access status of each client within the session scope, so as to track the operation status of each client. The information stored in the session can obtain the valid data of these sessions when the browser makes subsequent requests. .
You can use the session object (the built-in object of jsp) directly in the jsp page, or you can get back the session object through pageContext.getSession() or request.getSession.
session can save user information and implement functions such as shopping carts.
HTTP protocol is a stateless protocol. The client sends a request to the server, and then the server returns a response. The connection is closed. The server does not save the relevant information about the connection, so during the next connection, The server no longer has previous connection information and cannot determine that this connection has the same client information as the previous connection. Therefore, a session must be used to record information about the connection.
From the moment the client opens the browser to connect to the server to the moment the client closes the browser and leaves the server, it is called a session. When a client accesses the server, he or she may repeatedly connect to several pages on the server, repeatedly refresh a page, or continuously submit information to a page, etc. The server should know that this is the same client through some method, and then a session is needed. object.
1. When a customer accesses a page on the server for the first time, the server will allocate a session object to the user and specify a unique ID for the session, and Send the ID to the client and write it into the cookie, so that the client and the server's session establish a one-to-one correspondence;
2. When the client continues to access other resources on the server, the server no longer A new session object is allocated to the client until the client browser is closed, times out, or the invalidate() method of the session is called to invalidate it, and the session between the client and the server ends.
3. When the customer reopens the browser to access the website, the server will reassign a session object to the customer and reassign the sessionID.
1, public void setAttribute(String name,String value)
Set the specified name The value of the attribute and adds it to the session scope. If this attribute exists within the session scope, changes the value of the attribute.
2, public Object getAttribute(String name)
Get the value of the attribute with the specified name in the session scope. The return value type is object. If the attribute does not exist, null is returned.
3. public void removeAttribute(String name)
, delete the session attribute with the specified name. If the attribute does not exist, an exception will occur.
4, public void invalidate()
, invalidate the session. The current session can be invalidated immediately, and all objects stored in the original session can no longer be accessed.
5, public String getId( )
, get the current session ID. Each session has a unique identifier sessionID on the server side. The only data sent by the session object to the browser is the sessionID, which is generally stored in a cookie.
6, public void setMaxInactiveInterval(int interval)
Set the maximum duration of the session in seconds. A negative number indicates that the session will never expire.
7, public int getMaxInActiveInterval()
, Get the maximum duration of the session.
8. Use the getCreationTime() and getLastAccessedTime() methods of the session object to obtain the session creation time and last access time, but the return value is milliseconds. Generally, you need to use the following conversion to obtain the specific date and time. time.
Date creationTime = new Date(session.getCreationTime()); Date accessedTime = new Date(session.getLastAccessedTime());
<%@ page language="java" import="java.util.*" contentType="text/html;charset=GBK"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>" rel="external nofollow" > <title>session对象方法</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css" rel="external nofollow" > --> </head> <body> <b> 会话ID:<%=session.getId() %> <br> 是否新会话:<%=session.isNew() %><br> 设置和获取属性对象:用户名 = <%session.setAttribute("用户名","bing"); %> <%=session.getAttribute("用户名") %><br> <% Date creationTime = new Date(session.getCreationTime()); Date accessedTime = new Date(session.getLastAccessedTime()); %> 会话创建时间:<%=creationTime %><br> 上次访问时间:<%=accessedTime %><br> 会话持续时间(s):<%=session.getMaxInactiveInterval() %><br> <%session.setMaxInactiveInterval(12); %> 修改后的会话持续时间(s):<%=session.getMaxInactiveInterval() %><br> <%session.invalidate(); %> </b> </body> </html>
HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
(1)
ActionContext context = ActionContext.getContext(); Map request = (Map) context.get("request"); Map session = context.getSession(); Map application = context.getApplication();
(2)
ActionContext actionContext = ActionContext.getContext(); HttpServletRequest request = (HttpServletRequest) actionContext .get(ServletActionContext.HTTP_REQUEST); HttpSession session = request.getSession(); ServletContext context = (ServletContext) actionContext .get(ServletActionContext.SERVLET_CONTEXT);
HttpServletRequest request = ServletActionContext.getRequest(); HttpSession session = request.getSession();through ServletActionContext
The above is the detailed content of Analysis of session objects and method instances in java. For more information, please follow other related articles on the PHP Chinese website!