servlet会话技术

一、cookie会话。

(一)创建Cookie

1.创建cookie

Cookie cookie=new Cookie("name","zhangsan");//cookie里面不可以放中文。如果需要放中文必须要进行编码

Cookie cookie=new Cookie("name",java.net.URLEncoder.encode("张三","utf-8"));//编码

java.net.URLDecoder.decode(cookie.getValue(),"utf-8")//解码

2.设置cookie的生命周期(秒)

cookie.setMaxAge(3600);

cookie.setMaxAge(负数);//浏览器关闭之后就会失效

cookie.setMaxAge(0);//删除此cookie

3.把cookie信息回写给浏览器

response.addCookie(cookie);//这句话很重要,每当删除cookie.setMaxAge(0)都要回写过去;

(二)读取Cookie

1.读取所有的cookie信息

Cookie cookies[]=request.getCookie();

2.遍利所有的cookie

for(int i=0;i<cookies.length;i++){

      Cookie cookie=cookies[i];

      System.out.println("name:"+cookie.getName()+"value是:"+cookie.getValue());

  }

3.删除某个cookie:

首先找到那个cookie例如:

Cookie cookies[]=request.getCookie();

for(int i=0;i<cookies.length;i++){

      Cookie cookie=cookies[i];

     if(cookie.getName().equals("name")){

        cookie.setMaxAge(0);

        response.addCookie(cookie)//一定要回写否则不能删除。

     }

  }

(三)cookie的小结

1.cookie是在服务器端创建保存在浏览器这端

2.一个浏览器只能存放300个cookie

3.一个站点只能存放20个cookie

二、session技术

(一)、访问session当发现没有session的时候,就会自动创建session

HttpSession session=request.getSession();

(二)给session放入属性

setAttribute(String,Object);例如:

session.setAttribute("uname","宋江");

(三)设置session的生命周期(为20秒)

session.setMaxInactiverval(20);

(四)删除session

1.关闭服务器或者reload了web应用session会失效。

2.通过函数invalidate();

(五)删除session中的某个属性

使用removeAttribute(“name”);例如:

session.removeAttribute("uname");

(六)seeion小结

1.sessions是保存在服务器端

2.seesions是针对浏览器,web应用对不同浏览器创建不同的session.


你可能感兴趣的:(servlet会话技术)