单点登录系列之——HTTP请求与Cookie讲解



HTTPCookieSession

     HTTP协议作为无状态协议,无状态并不陌生,EJB bean中就有有状态、无状态之分,对于HTTP协议而言,无状态同样指每次request请求之前是相互独立的,当前请求并不会记录它的上一次请求信息。那么问题来了,既然无状态,那完成一套完整的业务逻辑,发送多次请求的情况数不胜数,使用http如何将上下文请求进行关联呢?机智的人类通过优化,找到了一种简单的方式记录http协议的请求信息

优化后的HTTP请求:

  1. 浏览器发送request请求到服务器,服务器除了返回请求的response之外,还给请求分配一个唯一标识ID,协同response一并返回给浏览器。

  2. 同时服务器在本地创建一个MAP结构,专门以key-value(请求ID-会话内容)形式将每个request进行存储

  3. 此时浏览器的request已经被赋予了一个ID,第二次访问时,服务器先从request中查找该ID,根据ID查找维护会话的content内容,该内容中记录了上一次request的信息状态。

  4. 根据查找出的request信息生成基于这些信息的response内容,再次返回给浏览器。如果有需要会再次更新会话内容,为下一次请求提供准备。

    所以根据这个会话ID,以建立多次请求-响应模式的关联数据传递。说到这里可能已经唤起了大家许多共鸣。这就是cookiesession对无状态的http协议的强大作用。服务端生成这个全局的唯一标识,传递给客户端用于唯一标记这次请求,也就是cookie;而服务器创建的那个map结构就是session所以cookies服务端生成,用于标记客户端的唯一标识,无特定含义,在每次网络请求中,都会被传送。session服务端自己维护的一个map数据结构,记录key-content上下文内容状态

Cookie7大属性

Namevaluecookie最常用的两个属性,也是用于标识当前cookieid和对应内容的属性。

Expires

用于设置cookie生命周期。

Path&domain

Pathdomain是针对于不同路径、跨域请求中对cookie进行设置的属性。举个简单的例子,浏览器访问百度的cookie一定不会发送给新浪网;访问百度新闻时登录的信息同样可以用于百度网盘,虽然他们并非同一请求路径下生成的cookie。这就是cookie的域和路径的属性。浏览器发出请求时,会根据cookiedomainpath属性确定是否传送cookie信息。默认情况下,只会在同域同路径下的cookie才会被传输。

httpOnly&secure

httpOnlysecure属性是cookie用于设置协议的种类,如果设置了httpOnly则只有在http协议下对该cookie才可见。Securehttps时可见。这两个属性主要是为了对cookie信息进行保护。

使用java语言操作cookie

//get cookie信息
		Cookie[] cookies=req.getCookies();
		if(cookies!=null)
		{
			System.out.println(
					cookies[0].getName()+","
					+cookies[0].getMaxAge()+","
					+cookies[0].getDomain()+","
					+cookies[0].getPath()+","
					+cookies[0].getValue()+","
					+cookies[0].getSecure()+","
					+cookies[0].isHttpOnly());	
		}
		//写入cookie	
		Cookie cookie=new Cookie("mycookieID", String.valueOf(System.currentTimeMillis()));
		cookie.setHttpOnly(true);
		cookie.setMaxAge(24*60*60);//24小时后过期 -以秒为单位的,基于当前时间的有效值
		cookie.setDomain("www.max.com"); //设置域名,表示该cookie仅对www.max.com是有效
		cookie.setPath("/");//设置路径为根路径,表示该cookie对根路劲下所有path有效
		//将cookie返回给浏览器
		resp.addCookie(cookie);
		
		//删除cookie
		//cookie是没有真正的删除操作的,只能通郭cookie的有效时间,设置为负值即可。过去时间的cookie
		cookie.setMaxAge(-1);

使用cookie需注意

  1. cookie数量过多过大,浪费网络流量,因为每次请求都会带着cookie,如果cookie过多或单个cookie携带信息较大,都会造成网络资源浪费;

  2. Cookie不适用于对敏感重要信息进行存储,因为浏览器中通过调试都可以看到该cookie具体信息,且每次都会在客户端缓存,所以针对一些重要密码等信息不应使用cookie进行存储.


  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值