Your Ad Here
首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 冲浪宝典 > 网络资源 > 由JSESSIONID谈cookie与SESSION的区别和联系
【标  题】:由JSESSIONID谈cookie与SESSION的区别和联系
【关键字】:JSESSIONID,cookie,SESSION
【来  源】:http://blog.chinaunix.net/article.php?articleId=26265&blogId=3787

由JSESSIONID谈cookie与SESSION的区别和联系

Your Ad Here 在一些投票之类的场合,我们往往因为公平的原则要求每人只能投一票,在一些WEB开发中也有类似的情况,这时候我们通常会使用COOKIE来实现,例如如下的代码:
 <  % cookie[]cookie= request.getCookies();
if (cookies.lenght == 0 || cookie== null)
    doStuffForNewbie();
//没有访问过    
}

else
{
    doStuffForReturnVisitor(); 
//已经访问过了
}

 
%  >


           这是很浅显易懂的道理,检测COOKIE的存在,如果存在说明已经运行过写入COOKIE的代码了,然而运行以上的代码后,无论何时结果都是执行doStuffForReturnVisitor(),通过控制面板-Internet选项-设置-察看文件却始终看不到生成的cookie文件,奇怪,代码明明没有问题,不过既然有cookie,那就显示出来看看。
cookie[]cookie= request.getCookies();
if (cookies.lenght == 0 || cookie== null)
    out.println(
"Has not visited this website");
}

else
{
    
for (int i = 0; i < cookie.length; i++)
    {
        out.println(
"cookie name:" + cookies[i].getName() + "cookie value:" +
            cookie[i].getValue());
    }
}


            运行结果:
cookie name:JSESSIONID cookie value:KWJHUG6JJM65HS2K6  

 为什么会有cookie呢,大家都知道,http是无状态的协议,客户每次读取web页面时,服务器都打开新的会话,而且服务器也不会自动维护客户的上下文信息,那么要怎么才能实现网上商店中的购物车呢,session就是一种保存上下文信息的机制,它是针对每一个用户的,变量的值保存在服务器端,通过SessionID来区分不同的客户,session是以cookie或URL重写为基础的,默认使用cookie来实现,系统会创造一个名为JSESSIONID的输出cookie,我们叫做session cookie,以区别persistent cookies,也就是我们通常所说的cookie,注意session cookie是存储于浏览器内存中的,并不是写到硬盘上的,这也就是我们刚才看到的JSESSIONID,我们通常情是看不到JSESSIONID的,但是当我们把浏览器的cookie禁止后,web服务器会采用URL重写的方式传递Sessionid,我们就可以在地址栏看到sessionid=KWJHUG6JJM65HS2K6之类的字符串。
             明白了原理,我们就可以很容易的分辨出persistent cookies和session cookie区别了,网上那些关于两者安全性的讨论也就一目了然了,session cookie针对某一次会话而言,会话结束session cookie也就随着消失了,而persistent cookie只是存在于客户端硬盘上的一段文本(通常是加密的),而且可能会遭到cookie欺骗以及针对cookie的跨站脚本攻击,自然不如session cookie安全了。
             通常session cookie是不能跨窗口使用的,当你新开了一个浏览器窗口进入相同页面时,系统会赋予你一个新的sessionid,这样我们信息共享的目的就达不到了,此时我们可以先把sessionid保存在persistent cookie中,然后在新窗口中读出来,就可以得到上一个窗口SessionID了,这样通过session cookie和persistent cookie的结合我们就实现了跨窗口的session tracking(会话跟踪)。
            在一些web开发的书中,往往只是简单的把Sessioncookie作为两种并列的http传送信息的方式,session cookies位于服务器端,persistent cookie位于客户端,可是session又是以cookie为基础的,明白的两者之间的联系和区别,我们就不难选择合适的技术来开发web service了。

TOO CLEVER FOR WORDS: ORACLE9I LOG MINER:【上一篇】
讨论:数据库管理员职责:【下一篇】
【相关文章】
  • session和cookie
  • Session 对象
  • 设置session时间
  • 关于session的问题集锦解决方案
  • PHP 会话 (Session) 使用入门
  • php中用session文件计算在线人数
  • 跨服务器共享session
  • session_cache_limiter (PHP4 CVS only)
  • Cookie技术
  • session_cache_limiter 及 session 问题
  • 【随机文章】
  • safeword agent在solaris下的安装和配置
  • 关于JBuilder 2007
  • AJAX设计策略(一)
  • 深入理解linux启动过程
  • 一个同事做的ftp性能测试
  • 真令人惊讶
  • 990DSL环路测试仪
  • 顶!Alexa排行之www.mobi123.cn(手机网址之家)再上120,103位
  • 《MS SQL Server 2000管理员手册》系列——13. T-SQL 与 SQL Query Analyzer
  • QQ木马的简单实现,QQ盗号核心编程。。。。
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 软讯网络 All Rigths Reserved.