session的应用场景,实现效果:欢迎您:XXX

项目目录

image

Login.java

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class Login extends HttpServlet {
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        String username = req.getParameter("username");
        req.getSession().setAttribute("username",username);
        resp.setContentType("text/html;charset=UTF-8");
        resp.sendRedirect("/session_last_login_username_war_exploded/index.jsp");

    }
}

login.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="Login" method="post"  >
    用户名:<input type="text" name="username">
    <input type="submit" value="登录">
</form>

</body>
</html>

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1">
    <servlet>
        <servlet-name>Login</servlet-name>
        <servlet-class>Login</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>Login</servlet-name>
        <url-pattern>/Login</url-pattern>
    </servlet-mapping>
</web-app>

效果

登录记住用户名.gif

发现

server端的session是针对每一个client创建一个session,session对象里的属性:id是区分不同client的关键。

最初client访问server时,server针对每一个client创建一个session,该session对象的属性:id=XXXXX,然后创建cookie,属性name=jsessionid,value=XXXXX,返回给客户端。下次访问server时,以此来判断是哪个client。


image.png

在刚才的场景里,client1登录后,server创建该client1的session,属性username = 111。client2登录后,server创建该client2的session,属性username = 444。互不影响。


image
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容