一Session

1概念:

(1)session是会话,是同一连接者所有页面公有的内置对象
  (2)session是一段时间,从session创建开始,到session销毁结束,默认时间为30分钟(即从最后一次访问页面开始计时)
  (3)session可以有多次请求和响应
 2 特点:
  (1)数据存储在服务器的内存中,所以数据是安全的
  (2)耗费内存资源
 3 实现保存用户状态的原理:
  (1)客户端第一次请求服务器时,服务器会生成应该唯一的sessionid并响应发送给客户端,sessionid在各浏览器不能共享
  (2)客户端再次发送请求时,服务器会根据客户端发来的sessionid与服务器中存储的sessionid进行匹配,匹配成功则可以拿数据,不成功则分配新的sessionid和存储区域

4 session对象常用的方法
  (1)getId():获得当前session的sessionid
  (2)setAttribute():向session空间中存储对象
  (3)getAttribute():从当前session对象获得相匹配的对象
  (4)invalidate():销毁所有的session对象
  (5)removeAttribute():移除某一个指定的session对象
  (6)getCreationTime():获得当前session创建的时间
  (7)getcLastAcessedTime():获得客户端最后一次请求服务器的时间
  (8)setMaxlnactivelnterval():设置session的最大请求间隔时间,单位为秒
  (9)getMaxlnactivelnterval():获得session的最大请求间隔时间,单位为秒
 5 session将用户信息保存在服务器端的内存中,信息比较安全但服务器端负担较重

二 Cookie
 1 概念:
  (1)cookie不是内置对象,使用时需要创建
  (2)cookie的创建:Cookie cookie =new Cookie(“”,“”)
  (3)cookie的构造参数需要两个参数,一个参数是cookie的名称,一个参数是cookie的值
 2 特点:

(1)数据默认存储在浏览器内存中,叫临时cookie,所以数据是不够安全的
  (2)不会耗费内存资源
 3 cookie的常用方法:
  (1)setMaxAge():设置cookie的存活时间
  (2)getName():获得cookie的名称
  (3)getValue():获得cookie的值

4 请求和响应

  (1)response.addCookie():将Cookie发送给客户端,即将cookie的键和值写到浏览器中
  (2)request.getCookies():从浏览器中获取所有的cookie内容
 5 cookie的存储时间:
 (1)setMaxAge():立即过期
  (2)setMaxAge():设置cookie的存活时间,单位为秒
 6 cookie默认不识别中文,需要设置后才可以使用
  (1)需要使用URLEncoder的encode方法将汉字编码后存储:userName = URLEncoder.encode(userName, "utf-8");
  (2)需要使用URLDecoder的decode方法将汉字装换编码后读取:userName = URLDecoder.decode(userName,"utf-8");

7 cookie的其他用法(仅了解):
  (1)设置域:setDomain(“其他网址”):本网址的cookie可以被其他网址读取
  (2)设置路径:setPath(“/....”):为了区分表示不同路径下的相同的cookie键
三 Session和Cookie的区别:
 1 存储位置:
  (1)session:数据存储在服务器的内存中,耗费内存资源
  (2)cookie:数据默认存储在浏览器内存中,不会耗费内存资源
 2 数据安全性:
  (1)session:信息比较安全
  (2)cookie:信息不够安全

3 保存的时间: 
  (1)session:不能持久地保存信息 
  (2)cookie:能够长期保存信息 
 4 值类型: 
  (1)session:值是Object类型的 
  (2)cookie:值是String类型的
---------------------
作者:gongchengshiaa
来源:CSDN
原文:https://blog.csdn.net/gongchengshiaa/article/details/54630399
版权声明:本文为博主原创文章,转载请附上博文链接!

Session&Cookie(Introduction、Application)的更多相关文章

  1. webform基础介绍及页面传值(session,cookie)、跳转页面

    一,IIS 1.首先知道IIS是个什么东西:它是web服务器软件,安装在服务器上,接受客户端发来的请求,并传送给服务器端,然后响应请求并送回给客户端.类似于饭店里的服务员. 2.会安装IIS——控制面 ...

  2. Session &cookie introduction,usage

    Cookie 1)什么是Cookie?      服务器为了识别用户身份而临时存放在浏览器端的少量数据.     2)工作原理         浏览器访问服务器时,服务器将一些数据以set-cooki ...

  3. session & cookie(li)

    Session & Cookie 一.定义 Session,用户在浏览某个网站时,从进入网站到浏览器关闭所经过的这段时间,也就是用户浏览这个网站所花费的时间.Cookie,由服务器端生成,发送 ...

  4. C#-WebForm-★内置对象简介★Request-获取请求对象、Response相应请求对象、Session全局变量(私有)、Cookie全局变量(私有)、Application全局公共变量、ViewState

    内置对象: 1.Request - 获取请求对象 用法:接收传值 protected void Page_Load(object sender, EventArgs e) { TextBox1.Tex ...

  5. application、session、request、page的作用范围、Application,Session和Cookie的区别

    Web应用中的JSP和servlet都是由web服务器来调用,Jsp和Servlet之间通常不会相互调用,那么Jsp和Servlet之间交换数据就要用到application.session.requ ...

  6. Application,Session,Cookie,ViewState,Cache对象用法、作用域的区别

    1.Application:用于保存所有用户共用的数据信息.在Asp.Net中类似的配置数据最好保存在Web.config文件中.如果使用Application对象,一个需要考虑的问题是任何写操作都要 ...

  7. URL、Session、Cookies、Server.Transfer、Application和跨页面传送,利弊比较

    URL.Session.Cookies.Server.Transfer.Application和跨页面传送.-本题考查面试者对ASP.NET中多页面传值的理解是否全面.因为ASP.NET的页面表单提交 ...

  8. [Asp.Net]状态管理(Session、Application、Cache)

    上篇博文介绍了在客户端状态管理的两种方式:http://www.cnblogs.com/wolf-sun/p/3329773.html.除了在客户端上保存状态外,还可以在服务器上保存状态.使用客户端的 ...

  9. Asp.net 服务器Application,Session,Cookie,ViewState和Cache区别

    2.8 Context 的使用Context 对象包含与当前页面相关的信息,提供对整个上下文的访问,包括请求.响应.以及上文中的Session 和Application 等信息.可以使用此对象在网页之 ...

随机推荐

  1. Oracle启动关闭

    启动: [oracle@oracleSigle ~]$ sqlplus / as sysdba   SQL*Plus: Release 11.2.0.1.0 Production on Wed Nov ...

  2. SpringBoot-@RequestParam

    Request参数 在访问各种各样网站时,经常会发现网站的URL的最后一部分形如:?xxxx=yyyy&zzzz=wwww.这就是HTTP协议中的Request参数,它有什么用呢?先来看一个例 ...

  3. JavaScript 模拟 Dictionary

    function Dictionary() { var items = {}; //判断是否包含Key值 this.has = function(key) { return key in items; ...

  4. axios实现拦截器

    项目中通常使用token进行用户权限认证,需要在请求的header中添加token信息进行验证,拦截返回的状态码进行跳转或重新登陆,在全局配置这些不妥,所以新建一个axios实例进行项目的配置. // ...

  5. java之动态代理

    摘要 相比于静态代理,动态代理避免了开发人员编写各个繁锁的静态代理类,只需简单地指定一组接口及目标类对象就能动态的获得代理对象. 这里说的静态代理可以理解为之前使用的装饰者模式,从之前使用装饰者模式实 ...

  6. VoiceXML简介

    简单来说,VoiceXML就是语音网络世界的HTML,一种用于语音应用的开放标准的标记语言.VoiceXML的问世使得为HTML发展起来的web体系也能够轻松地创建和使用语音应用. 发展历史: 199 ...

  7. [sql]sql的select字符串切割

    可以经常看看 mysql的refman,写的很棒 sql基础操作 查看表结构 show create table desc table show full columns from test1; li ...

  8. 修改jupyter notebook的默认打开地址

    1)在Anaconda Prompt终端中输入下面命令,查看你的notebook配置文件在哪里: jupyter notebook --generate-config 2)通过搜索关键词:c.Note ...

  9. InternalError (see above for traceback): Blas GEMM launch failed

    训练BiLSTM模型的时候报错: InternalError (see above for traceback): Blas GEMM launch failed : a.shape=(32, 200 ...

  10. mysql 事务锁超时时间 innodb_lock_wait_timeout

    mysql 事务锁超时时间 innodb_lock_wait_timeout: # 查询全局等待事务锁超时时间 SHOW GLOBAL VARIABLES LIKE 'innodb_lock_wait ...