?
? ? ? ? ?当我们打开浏览器,在浏览器上访一个网站,不管在网站里点击多少个超链接、访问多少资源,一直到关闭浏览器,这一整个过程就是一个会话。 ? 1.2、会话中常需要解决的问题 ? ? ? ? 用户与服务器的交互会话过程中,每个用户都会存在自己的一些数据,例如登录后记住登录状态,用户访问过的资源信息、网上购物选购的商品信息....... ? ? ? ?对于某些会话数据,有时候程序必须想办法保存这些数据: 1.3、保存会话数据的两种技术——cookie & session ? ?下面主要是本人自己的一些理解,使用的例子都较为基础,更多使用方法可以通过查阅API。 1.3.1、cookie 什么是cookie? ? ? ? ?cookie形式的文件其实一般就是一个txt文档,只是文档里以某种格式保存数据的。 java中使用cookie:要导入javax.servlet.http.Cookie这个包 ? ? ? ? //1.添加一个cookie到客户端, ? ? ? ? ? ?Cookie c2 = new Cookie("password","123"); ? ? ? ? ?c2.setMaxAge(3600); ? ??//设置生命周期为1小时,秒为单位 ? ? ? ? ?response.addCookie(c2);//向浏览器添加一个cookie ? ? ? } ? ? ?如果在添加cookie时没有设置生命周期,那这个cookie只存在客户端的内存中,并未写到硬盘文件中(如果客户端关闭?此浏览器窗口,就丢失了) ? ?如果设置了生命周期,那么就会将此cookie写到硬盘文件中,直到设置的生命周期结束才会失效。 ? //2.读取cookie文件 public void getCookies(){ ? ? ? ? ? ? ?Cookie[] cookies = request.getCookies(); ?//首先要取得浏览器上所有的cookie,返回一个数组 ? ? ? ? ? ? for(Cookie c :cookies ){ ? ? ? ? ? ? ? ? ? ? ?//遍历查找名为username的cookie ? ? ? ? ? ? ? ? ? ? ? ? ?System.out.println(c.getName()+"--->"+c.getValue()); ? ? ? ? ? ? ? ? ? } ? ? ? ? ? ? } ? ? ?} ? //3.删除cookie文件,可以将cookie的生命周期设置为0,浏览器就会将其删除 ? ? ? ?Cookie c1 = new Cookie("username",null); ? ? ? ?c1.setMaxAge(0); ? ? ? ?response.addCookie(c1); ? 1.3.2、session 什么是session? ? ? ? ?因为是保存在服务器的内存中,所以当会话结束(浏览器关闭),对应的session也会结束。 ? java中使用session:要导入javax.servlet.http.HttpSession这个包 //1.添加一个session到服务器 ? ? public void addSession(){ ? ? ? ? ? HttpSession session = request.getSession(); ? ? ? ? ? session.setAttribute("username","su"); //向服务器添加一个名为username的session ? ? ?} ? //2.获取一个session的值 ? ? public void getSession(){ ? ? ? ? ? String username =(String) session.getAttribute("username"); ? ? ?} ? //3.删除session ? ? public void deleteSession(){ ? ? ? ? ? HttpSession session = request.getSession(); ? ? ? ? ? session.removeAttribute("变量名");?//删除某个sessionclass="best-text mb-10"> ? ? ? ? ? session.invalidate(); //删除所有session
? ? ?}
?