cookie及session

    科技2022-07-11  93

    cookie原理及应用

    1.cookie的工作原理

    1.Cookie是将会话中产生的数据保存在客户端,是客户端技术。 2.Cookie是基于两个头进行工作的:分别是Set-Cookie响应头和Cookie请求头 3.通过Set-Cookie响应头将cookie从服务器端发送给浏览器,让浏览器保存到内部;而浏览器—旦保存了cookie,以后浏览器每次访问服务器时,都会通过cookie请求头,将cookie信息再带回服务器中。在需要时,在服务器端可以获取请求中的cookie中的数据,从而实现某些功能。

    2.cookie的API及应用

    2.1 创建Cookie对象

    Cookie c = new Cookie(String name, String value); // 创建cookie的同时需要指定cookie的名字和cookie要保存的值 // Cookie的名字一旦指定后,就无法修改!

    2.2 将Cookie添加到response响应中

    response.addCookie( Cookie c ); // 将cookie添加到响应中,由服务器负责将cookie信息发送给浏览器,再由浏览器保存到内部(可以多次调用该方法,添加一个以上的cookie)

    2.3 获取请求中的所有cookie对象组成的数组

    Cookie[] cs = request.getCookies(); // 获取请求中携带的所有cookie组成的cookie对象数组,如果请求中没有携带任何cookie,调用该方法会返回null。

    2.4 删除浏览器中的Cookie

    // cookie的API中没有提供直接删除cookie的方法,可以通过别的方式间接删除cookie // 删除名称为cart的cookie:可以向浏览器再发送一个同名的cookie(即名称也叫做cart),并设置cookie的最大生存时间为零,由于浏览器是根据cookie的名字来区分cookie,如果前后两次向浏览器发送同名的cookie,后发送的cookie会覆盖之前发送的cookie。而后发送的cookie设置了生存时间为零,因此浏览器收到后也会立即删除!

    代码示列:

    //创建一个名称为cart的cookie Cookie c = new Cookie("cart", ""); //设置cookie的最大生存时间为零 c.setMaxAge( 0 ); //将cookie添加到响应中,发送给浏览器 response.addCookie( c ); out.write( "成功删除了名称为cart的cookie..." );

    2.5 Cookie的常用方法

    cookie.getName(); // 获取cookie的名字 cookie.getValue(); // 获取cookie中保存的值 cookie.setValue(); // 设置/修改cookie中保存的值(没有setName方法,因为cookie的名字无法修改) cookie.setMaxAge(); //设置cookie的最大生存时间(如果不设置,cookie默认在一次会话结束时销毁!)

    2.6 setMaxAge方法:设置cookie的最大生存时间

    1、如果不设置该方法,cookie默认是会话级别的cookie,即生存时间是一次会话。当浏览器关闭,会话结束时,cookie也会被销毁(cookie默认存在浏览器的内存中,当浏览器关闭,内存释放,cookie也会随着内存的释放而销毁。)

    2、如果设置了该方法,cookie将不会保存到浏览器的内存中,而是以文件形式保存到浏览器的临时文件夹中(也就是硬盘上),这样再关闭浏览器,内存释放,保存到硬盘上的cookie文件不会销毁,再次打开浏览器,还可以获取硬盘上的cookie信息。

    代码示例:

    //创建一个Cookie对象,将商品信息保存到cookie中 Cookie cookie = new Cookie( "cart", prod ); //设置cookie的最大生存时间, 单位:秒 cookie.setMaxAge( 60*60*24 ); //将cookie对象添加到response响应中 response.addCookie( cookie );

    session原理及应用

    1.session的工作原理

    1.Session是将会话中产生的数据保存在服务器端,是服务器端技 术 2.Session是一个域对象,session中也保存了一个map集合,往 session中存数据,其实就是将数据保存到session的map集合 中。 3.通过session.setAttribute()方法可以将数据保存到session中, 通过session.getAttribute()方法可以将数据从session中取出 来。

    2.session是一个域对象

    2.1 获取session对象

    request.getSession() // 获取一个session对象;如果在服务器内部有当前浏览器对应的session,则直接返回该session对象;如果没有对应session,则会创建一个新的session对象再返回;

    2.2 Session是一个域对象,session中也保存了一个map集合,并且session中也提供了存取数据的方法

    示例:

    session.setAttribute(String attrName, Object attrValue); // 往session域中添加一个域属性,属性名只能是字符串类型,属性值可以是任意类型。 session.getAttribute(String attrName); // 根据属性名获取域中的属性值,返回值是一个Object类型

    3.session域对象的三大特征

    3.1 生命周期:

    创建session: 第一次调用request.getSession()方法时,会创建— 个session对象。(当浏览器在服务器端没有对应的session时,调用request.getSession()方法服务器会创建一个session对象。) 销毁session: 1.超时销毁:默认情况下,当超过30分钟没有访问session,session就会超时销毁。(30分钟是默认时间,可以修改,但不推荐修改) 2.自杀:调用session的invalidate方法时,会立即销毁session。 3.意外身亡:当服务器非正常关闭时(硬件损坏,断电,内存溢出等导致服务器非正常关闭), session会随着服务器的关闭而销毁; 当服务器正常关闭,在关闭之前,服务器会将内部的session对象序列化保存到服务器的work目录下,变为一个文件。这个过程叫做session的钝化(序列化)﹔再次将服务器启动起来,钝化着的session会再次回到服务器,变为服务器中的对象,这个过程叫做session的活化(反序列化)。

    3.2 作用范围:

    在一次会话范围内(获取到的都是同一个session对 象)

    3.3 主要功能:

    在整个会话范围内实现数据的共享

    cookie及session的区别

    Cookie和session都属于会话技术,都可以保存会话中产生的数据,但由于cookie和session的工作原理和特点不同,因此两者的应用场景也不一样。

    Cookie的特点: 1.cookie是将会话中产生的数据保存在浏览器客户端,是客户端技术(JS可以访问cookie) 2.cookie是将数据保存在客户端浏览器,容易随着用户的操作导致cookie丢失或者被窃取,因此cookie中保存的数据不太稳定,也不太安全。 3.但cookie将数据保存在客户端,对服务器端没有太多影响,可以将数据保存很长时间。 4.总结:因此cookie中适合存储需要长时间保存、但对安全性要求不高的数据。 5.浏览器对cookie的大小和个数都有限制,一般推荐每一个站点给浏览器发送的cookie数量不超过20个,每一个cookie的大小不超过1kb。 6.Cookie的应用:实现购物车、记住用户名、30天内自动登录等。

    session的特点 1.session是将会话中产生的数据保存在服务器端,是服务器端技术 2.session将数据存在服务器端的session对象中,相对更加的安全,而且更加稳定。不容易随着用户的操作而导致session中的数据丢失或者是被窃取。 3.但session是服务器端的对象,在并发量较高时每一个浏览器客户端在服务器端都要对应一个session对象,占用服务器的内存空间,影响效率。 4.总结:因此session中适合存储对安全性要求较高,但不需要长时间保存的数据。 5.Session的应用:保存登录状态、保存验证码

    Processed: 0.027, SQL: 8