zoukankan      html  css  js  c++  java
  • cookie和session会话技术

    因为http协议是无状态的,也就是说每个客户端访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端状态。会话技术是帮助服务器记住客户端状态的。

    一次会话的开始是通过浏览器访问某个站点,结束是关闭这个浏览器的过程。会话技术就是记录这次会话中客户端的状态哦与数据的。会话技术分为两种,分别是cookie和session。

    1. cookie:数据存储到客户端本地,减少了服务器的存储压力,但安全性不好,客户端可以手动清除cookie
    2. session:将数据存储到服务器,安全性相对较好,但与此同时增加了服务器自身的压力。

    创建cookie:Cookie cookie = new Cookie("username","lisi");

    将cookie发送到浏览器:response.addCookie(cookie);

    cookie没有无参构造方法,且参数不能是中文。参数类型都是String,第一次设置cookie请求中不能看到,以后可以看到已设置的cookie,只要浏览器不关闭cookie依旧存在。

    为cookie设置持久化时间:cookie信息在硬盘上保留的时间

    cookie.setMaxAge(int seconds);例如:cookie.setMaxAge(10*60);设置时间为10分钟。

    为cookie设置携带的路径:cookie.setPath("/web/sendCookie");当访问sendCookie 时才携带这个cookie。Cookie.setPath("/");访问服务器下的所有资源都携带这个cookie。

    创建并发送cookie
    //1.创建cookie对象
    Cookie cookie=new Cookie("name","tian");
    
    //2.携带这个cookie的资源路径
    cookie.setPath("/cookie&session/sendServlet");
    
    //3.设置cookie对象持久化时间1分钟
    cookie.setMaxAge(60);
    
    //4,将cookie信息增加到客户端
    response.addCookie(cookie);//name:"tian"

    注意:如果不设置携带路径那么这个cookie信息会在访问产生该cookie的web 资源所在的路径都携带cookie信息。

    删除客户端携带的cookie:

    如果想删除客户端已存储的cookie信息那么就使用同名同路径的持久化时间为0的cookie进行覆盖即可。

    删除指定的cookie
    
    //1.找到同名的这个cookie,值可以不填
    Cookie cookie=newCookie("name","");
    //2.找到同路径下的cookie
    cookie.setPath("/web/sendCookie/");
    //3.将持久化时间设置0,删除成功
    cookie.setMaxAge(0);
    

    用cookie提示客户端上次访问的时间

    在此遇到了一个异常:

    java.lang.IllegalArgumentException: An invalid character [32] was present in the Cookie value

    在Tomcat9.0运行出现的异常,解决方法:

    Date date=new Date();

    SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd-hh:mm:ss");

    中间()内的时间格式不能含有空格,将空格去掉就行。

    response.setContentType("text/html;charset=UTF-8");
    Datedate=new Date();
    SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd-hh:mm:ss");
    String lastTime = format.format(date);
    
    //1.第一次访问创建cookie
    Cookie cookie=new Cookie("lastAccessTime",lastTime);
    cookie.setMaxAge(60*100);//100minutes
    response.addCookie(cookie);//添加到客户端
    
    //2,要找到这个cookie并判断他的值是否为空,若为空显示这是第一次访问,若不为空显示上次访问时间
    Cookie[] cookies = request.getCookies();
    String lastAccessTime = null;
    if(cookies!=null){
    for(Cookie coo : cookies){
    if(coo.getName().equals("lastAccessTime")){
      lastAccessTime=coo.getValue();
        }
      }
    }
    
    if(lastAccessTime!=null){
    //不是第一次访问
    response.getWriter().write("您上次访问的时间是:"+lastAccessTime);
    }else{
    response.getWriter().write("您是第一次访问这个页面!");
    }
    

    Session技术是将数据存储在服务器端的技术,会为每个客户端都创建一块内存空间    存储客户的数据,但客户端需要每次都携带一个标识ID去服务器中寻找属于自己的内   存空间。所以说Session的实现是基于Cookie,Session需要借助于Cookie存储客    户的唯一性标识JSESSIONID。

    1. 获得Session对象

        HttpSession session = request.getSession();

    此方法会获得专属于当前会话的Session对象,如果服务器端没有该会话的Session    对象会创建一个新的Session返回,如果已经有了属于该会话的Session直接将已有    的Session返回(实质就是根据JSESSIONID判断该客户端是否在服务器上已经存在    session了)

              2. 怎样向session中存取数据(session也是一个域对象)

    Session也是存储数据的区域对象,所以session对象也具有如下三个方法:

    1. session.setAttribute(String name,Object obj);
    2. session.getAttribute(String name);
    3. session.removeAttribute(String name);

    3.Session对象的生命周期

    创建:第一次执行request.getSession()时创建

    销毁:

    1. 服务器(非正常)关闭时
    2. session过期/失效(默认30分钟)
    3. 手动销毁session  session.invalidate();

     

    问题:时间的起算点 从何时开始计算30分钟?

    从不操作服务器端的资源开始计时,如果中间时间进行了操作那么就要重新计时

     

    可以在工程的web.xml中进行配置

    <session-config>

            <session-timeout>30</session-timeout>

    </session-config>

    session.invalidate();

     

    作用范围:

    默认在一次会话中,也就是说在,一次会话中任何资源公用一个session对象

     

    session的持久化,例如当我们创建一个servlet1,在servlet1中新见一个session,设置属性名和对应的值

    session.setAttribute("name","jerry");
    再建一个servlet2,在2中获取这个session对应的name值Jerry,当然是先访问1再访问2,当关闭浏览器时,再次打开访问2,得到的数据是null,因为session是基于cookie的,每次创建一个session会话,会得到一个jsessionid,客户端拿着这个id去找对应的session内存区域,但存储JSESSIONID的这个cookie默认是会话级别并没有设置持久化,所以当我们再次访问2的时候没有找到session内存区域,得到name对应的值是null,因此想要关闭浏览器后再次打开访问2得到值,可以将session持久化,方式如下:
    @WebServlet("/sessionServlet1")
    public class sessionServlet1 extends HttpServlet {
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
             doGet(request,response);
        }
    
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    
            HttpSession session = request.getSession();
            String id = session.getId();
            //将session持久化
            Cookie cookie = new Cookie("JSESSIONID",id);
            cookie.setPath("/cookie&session/");
            cookie.setMaxAge(60*10);//设置时间10分钟
            response.addCookie(cookie);
    
    
            response.getWriter().println(id);
            session.setAttribute("name","jerry");
    
        }
    }
    
    
    @WebServlet("/sessionServlet2")
    public class sessionServlet2 extends HttpServlet {
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            doGet(request,response);
        }
    
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            HttpSession session = request.getSession();
            String name = (String) session.getAttribute("name");
            response.getWriter().println("name: "+name);
    
        }
    }
    
  • 相关阅读:
    Masonry代码自动布局的简单使用。
    iOS app 如何添加引导页。
    iOS应用程序发布AppStore及更新流程
    AFN的简单二次封装
    自定义tabbar(纯代码)
    自定义tabbar(storyBoard)
    GitHub tag的使用
    cvGetSize与cvSize的区别
    越界访问,调试真的很头疼
    Hadoop对文本文件的快速全局排序
  • 原文地址:https://www.cnblogs.com/itjiangpo/p/14181463.html
Copyright © 2011-2022 走看看