会话:用户打开一个浏览器,点击了很多超链接,访问多个web资源,关闭浏览器,这个过程可以称之为会话
有状态会话:一个同学来过教室,下次再来教室,我们会知道这个同学,曾经来过,称之为有状态会话;
你能怎么证明你是西开的学生?
你 西开
一个网站,怎么证明你来过?
客户端 服务端
cookie
session
常见场景:网站登录之后,你下次不用再登录了,第二次访问直接就上去了!

Cookie[] cookies = req.getCookies(); //获得Cookiecookie.getName(); //获得cookie中的keycookie.getValue(); //获得cookie中的valuenew Cookie("lastLoginTime", System.currentTimeMillis()+""); //新建一个cookiecookie.setMaxAge(24*60*60); //设置cookie的有效期resp.addCookie(cookie); //响应给客户端一个cookiecookie:一般会保存在本地的用户目录下 appdata;
一个网站cookie是否存在上限!聊聊细节问题
删除Cookie:
编码解码:
URLEncoder.encode("秦疆","UTF-8")URLDecoder.decode(cookie.getValue(), "UTF-8")7.4、Session(重点)

什么是Session:

Session和cookie的区别:
使用场景:
使用Session:
public class SessionDemo01 extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { //解决乱码问题 req.setCharacterEncoding("utf-8"); resp.setCharacterEncoding("utf-8"); resp.setContentType("text/html;charset=utf-8"); //得到Session HttpSession session = req.getSession(); //给Session中存入东西 session.setAttribute("name",new Person("秦疆",1)); //获取Session的ID String sessionId = session.getId(); //判断Session是不是新创建的 if (session.isNew()){ resp.getWriter().write("session创建成功,ID:"+sessionId); }else { resp.getWriter().write("session已经在服务器中存在了,ID:"+sessionId); } //Session创建的时候做了什么事情: Cookie cookie = new Cookie("JSESSIONID", sessionId); resp.addCookie(cookie); } @Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { doGet(req, resp); }}==========================================//得到SessionHttpSession session = req.getSession();Person person = (Person) session.getAttribute("name");System.out.println(person.toString());==========================================HttpSession session = req.getSession();session.removeAttribute("name");//手动注销Sessionsession.invalidate();会话自动过期:web.xml配置
<!--设置Session默认的失效时间--><session-config> <!--15分钟后Session自动失效,以分钟为单位--> <session-timeout>15</session-timeout></session-config>