喜悦国际村 
» 游客:  注册 | 登录 | 搜索 | 统计 | 喜悦证交所 | 帮助

RSS 订阅当前论坛  

上一主题 下一主题
 18  1/2  1  2  > 
     
标题: [原创] COOKIE 和 SESSION  
 
wzhu (wzhu)
版主
Rank: 7Rank: 7Rank: 7
C[A-Z]O


UID 68040
精华 0
积分 47785
帖子 1559
金钱 47762 喜悦币
威望 0
人脉 23
阅读权限 100
注册 2006-1-14
来自 湖北荆州>陕西西安>辽宁 ...
状态 离线
COOKIE 和 SESSION

首先要明白以下几个基本知识:

1,浏览网页使用的是HTTP协议
2,HTTP协议是无状态的
3,整个过程是用户发出请求,服务器接受请求,作出响应,断开连接(无状态,不记录该连接记录)
4,HTTP协议包含协议头和消息实体两部分
5,Session在服务端,Cookie在客户端

过程
1,用户向服务器发送一个url请求。(GET /index.php HTTP/1.1)

2,服务器接受请求,在服务器上查找 index.php文件

3,根据该请求创建一个唯一的session_ID的文件按 一般在服务器的 %TEMP%文件夹下 如windows C:\winnt\temp\下面创建一个如:sess_e12683c5301033a408419cc9df284f7b的文件 (window2000)
  并将一些SESSION值保存在该文件里面


4,将处理结果返回给客户端,并把该session_ID或者其它信息放在响应的协议头里面(set-Cookie),具体信息根据设置来确定,服务器断开连接

5,客户端接收,浏览器将协议头里面的session_ID存放在客户端的一个文件里(cookie)文件
  在windows下一般在 C:\Documents and Settings\用户名\Local Settings\Temporary Internet Files下。

  cookie的文件名一般为
  Cookie:用户名@dommain


  Cookie文件的一般内容为

BAIDUID                                                                Cookie名称
25D4E67AC34F467A29DB9B8C85C4DEC5        Cookie值
baidu.com/                                                        Cookie有效路径
1024                                                                安全性 1024和1536表示模指数(MODP)群算法的位数
3577998080                                                        Cookie有效日期
32067270                                                        修改日期
1590083488                                                        建立日期
29862897                                                        建立者




6,客户端第二次向服务器发送请求,浏览器会将对应的cookie文件里面的值放在请求的协议头里面


7,服务接受协议头,同时也接受了cookie的值,这样服务器就可以和已经保存的session文件进行验证



说明
a,在上面的  3  步骤中,如果用户还保存其它的session值,这些值作为内容保存到那个session文件里面
b,在上面的  4  步骤中,服务还可以向客户端发送更多的cookie值
c,在上面的  5  步骤中,如果用户的浏览器拒绝cookie,那么有时候服务器会将session_ID作为url后面的参数附带,所以我们常常看见有的url上常常会有 PHPSESSID=******** 或者JSPSESSID=******之类的参数,如果浏览器接受cookie,也会将上面  b  中的更多参数放在cookie文件里面
d,在上面的  7  步骤中,服务器会根据session_ID查找对应的文session文件,因此也可以根据该文件的内容获取先前保存的其它的session值
e,在服务器保存的session文件有时间限制
f,在客户端保存的cookie文件有过期时间


以下是对cookie和session的形象说明

假设某一个酒店是服务器。
酒店没有必要对所有的会员都记录信息(无状态),也没有办法记住所有的会员,除非他是超人,牛B的很。
酒店只记录该店的VIP会员


如何记录会员并根据会员的消费来给于优惠呢?


方法一 ( 全部采用COOKIE )
酒店给每一位VIP会员一张卡,上面记录了 该会员的一切信息,包裹消费状况
优点:酒店不用保存任何信息。每位会员来消费,出示卡片就行了。
缺点:可以转借他人( 别人使用它的机器 ),可以伪造,会员丢失卡片将不再为本店会员(删除COOKIE)



方法二
酒店仍然给每位会员一张卡片,单卡片上除了一个帐号(session_id)或一些基本信息外什么都没有记录
酒店在本店里的账本上记录该会员的所有信息和帐号对应上(服务器的session文件)

会员来消费,出示卡片,酒店工作人员去核对


方法三
酒店通过会员的面相记住所有会员的姓名以及消费等所有信息(加入http是有状态的。)
会员以来,酒店就认识了。

不过这个基本上是不可能的。而且要求脑容量超级大。




通过上面我们可以看出来,及时你只是用session,其实也会给客户端发送一些信息,就像一把下次来认证的钥匙一样.




<?wzhu
wzhu.print("This is a wzhu language");
?>
2007-6-12 09:11 AM#1
查看资料  访问主页  Blog  发短消息  QQ  顶部
 
wzhu (wzhu)
版主
Rank: 7Rank: 7Rank: 7
C[A-Z]O


UID 68040
精华 0
积分 47785
帖子 1559
金钱 47762 喜悦币
威望 0
人脉 23
阅读权限 100
注册 2006-1-14
来自 湖北荆州>陕西西安>辽宁 ...
状态 离线
[推荐阅读] 请问村子里人脉的功能怎么实现的
以上纯属个人理解。如果有误,请指正。先谢过



<?wzhu
wzhu.print("This is a wzhu language");
?>
2007-6-13 08:13 AM#2
查看资料  访问主页  Blog  发短消息  QQ  顶部
 
熟人
中级会员
Rank: 3Rank: 3



UID 92185
精华 0
积分 332
帖子 476
金钱 332 喜悦币
威望 0
人脉 0
阅读权限 30
注册 2007-4-29
状态 离线
[推荐阅读] 求书...
套用hotdog的歌就是:一个萝卜一个坑 我也想分一杯羹 可是吃了闭门羹
cookie是萝卜 session是坑




性格:馋 懒 奸 猾 坏
兴趣:吃 喝 嫖 赌 抽
职业:坑 蒙 拐 骗 偷
2007-6-14 09:40 AM#3
查看资料  发短消息  顶部
 
wzhu (wzhu)
版主
Rank: 7Rank: 7Rank: 7
C[A-Z]O


UID 68040
精华 0
积分 47785
帖子 1559
金钱 47762 喜悦币
威望 0
人脉 23
阅读权限 100
注册 2006-1-14
来自 湖北荆州>陕西西安>辽宁 ...
状态 离线
[推荐阅读] 关于smarty缓存技术


QUOTE:
原帖由 熟人 于 2007-6-14 09:40 发表
套用hotdog的歌就是:一个萝卜一个坑 我也想分一杯羹 可是吃了闭门羹
cookie是萝卜 session是坑
细想有理,顶




<?wzhu
wzhu.print("This is a wzhu language");
?>
2007-6-14 10:08 AM#4
查看资料  访问主页  Blog  发短消息  QQ  顶部
 
oklilei
新手上路
Rank: 1



UID 81199
精华 0
积分 0
帖子 1
金钱 0 喜悦币
威望 0
人脉 0
阅读权限 10
注册 2006-10-9
状态 离线
[推荐阅读] 求PHP文件下载类一个
很形象,感谢了@
2007-6-15 12:53 PM#5
查看资料  发短消息  顶部
 
wzhu (wzhu)
版主
Rank: 7Rank: 7Rank: 7
C[A-Z]O


UID 68040
精华 0
积分 47785
帖子 1559
金钱 47762 喜悦币
威望 0
人脉 23
阅读权限 100
注册 2006-1-14
来自 湖北荆州>陕西西安>辽宁 ...
状态 离线
[推荐阅读] 痴情女子的真情表白--《女人如烟》(魏佳艺)
突然发现错别字一堆。!!!!!!!!!!!!



<?wzhu
wzhu.print("This is a wzhu language");
?>
2007-6-15 01:14 PM#6
查看资料  访问主页  Blog  发短消息  QQ  顶部
 
pangmen
注册会员
Rank: 2



UID 93881
精华 0
积分 90
帖子 85
金钱 90 喜悦币
威望 0
人脉 0
阅读权限 20
注册 2007-6-13
状态 离线
[推荐阅读] 专接: oscommerce,creloaded二次开发,项目修改
POST的过程,你是怎样理解的呢?
2007-6-20 12:05 AM#7
查看资料  发短消息  顶部
 
熟人
中级会员
Rank: 3Rank: 3



UID 92185
精华 0
积分 332
帖子 476
金钱 332 喜悦币
威望 0
人脉 0
阅读权限 30
注册 2007-4-29
状态 离线
[推荐阅读] xml的 问题
咋又扯上post了哪?



性格:馋 懒 奸 猾 坏
兴趣:吃 喝 嫖 赌 抽
职业:坑 蒙 拐 骗 偷
2007-6-20 07:55 AM#8
查看资料  发短消息  顶部
 
wzhu (wzhu)
版主
Rank: 7Rank: 7Rank: 7
C[A-Z]O


UID 68040
精华 0
积分 47785
帖子 1559
金钱 47762 喜悦币
威望 0
人脉 23
阅读权限 100
注册 2006-1-14
来自 湖北荆州>陕西西安>辽宁 ...
状态 离线
[推荐阅读] AJAX JS好工具---Aptana IDE


QUOTE:
原帖由 熟人 于 2007-6-20 07:55 发表
咋又扯上post了哪?
POST 和 GET其实没有很大的差别。

POST请求时, 数据参数等是放在实体里面的
具体格式如下

POST /index.php HTTP/1.1
Host: www.xxx.com
Content-Length: XXX
XXX

param1=value1&param2=value2

[ 本帖最后由 wzhu 于 2007-6-20 08:30 AM 编辑 ]




<?wzhu
wzhu.print("This is a wzhu language");
?>
2007-6-20 08:29 AM#9
查看资料  访问主页  Blog  发短消息  QQ  顶部
 
熟人
中级会员
Rank: 3Rank: 3



UID 92185
精华 0
积分 332
帖子 476
金钱 332 喜悦币
威望 0
人脉 0
阅读权限 30
注册 2007-4-29
状态 离线
[推荐阅读] Redefining already defined constructor for class xxx
Content-Type:multipart/form-data的时候有些不一样哦



性格:馋 懒 奸 猾 坏
兴趣:吃 喝 嫖 赌 抽
职业:坑 蒙 拐 骗 偷
2007-6-20 09:06 AM#10
查看资料  发短消息  顶部
 18  1/2  1  2  > 
     


  可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题 | 开通个人空间  


 


Powered by Discuz! 6.1.0  © 2001-2010 Comsenz Inc.
Processed in 0.027778 second(s), 6 queries

(冀ICP备05009913号) 管理员:sadly 邮箱/MSN: sadly@phpx.com QQ:824008(长隐) 清除 Cookies - - Archiver - WAP