cookies session和token ,和一个小案例

概念

cookie

cookie存储在客户端,HTTP是无状态的,HTTP每次发出的时候会附上该域名下的cookie,从而可以给HTTP附上状态,最常见的就是登录态。

session和token

session和token算是一类的,他们是两种不同的服务器的验证方式。
通俗来说,cookie会存一个value在客户端本地,然后将value附到HTTP上发给服务器,那么服务器是怎么通过这个value来判断用户是否是登录态的呢?这就是session和token做的事情。

session过程

请求过程:
1、客户端向服务器请求,发送用户名和密码
2、服务器生成sessionId,绑定用户数据存储在数据库
3、服务器返回sessionId给客户端
4、客户端用cookie存储sessionId,以后的请求都带上这个sessionId
5、服务器如果收到这个sessionId,那么就去数据库查找用户数据,如果找到了说明验证通过
6、服务器把验证结果返回客户端

image.png

token过程

请求过程:
1、客户端向服务器请求,发送用户名和密码
2、服务器根据用户信息通过加密生成token,用户信息包括账号,token过期时间等,具体由服务器自定义。
3、服务器返回token给客户端
4、客户端用cookie存储token,以后的请求都带上这个token
5、服务器把token解密,确认用户信息是否正确,如经过正确就说明验证通过。
6、服务器把验证结果返回客户端

image.png

session、token优劣

session

由于sessionId和用户信息相互绑定的数据库存在服务器,所以服务器可以随时让发送出去的一个sessionId失效。这是保障安全的一种重要手段。

token

token的好处是比session更省空间和时间,服务器不需要去管理sessionId和用户信息的数据库,服务器收到token直接解密就可以验证,不需要去数据库查找验证。
但是token发送出去之后,就只能等待它达到过期时间后才会失效,后台无法对其进行控制。


下面我们讲个实例加深下印象
比如教管系统,我们退出登录,我们按F12抓包,抓包的时候要设置下preserve log,我们刷新一下界面看一下,刷新之后我们看这个登录请求我们可以看到没有cookie字段

image.png

登录我们发请求的时候我们看一下请求头,请求头里面还是没有cookie字段

image.png

然后我们点击登录看一下响应(Response )里面有Set-Cookie的字段里面有sessionid在里面,这个就是cookie数据,他要求你把cookie里面设置一个sessionid数据存在客户端。

image.png

存上之后我们后续的请求,登录成功之后不是要访问主页了吗,后续请求请求头就带上了Cookie。

说道这里有没有同学想到,之前讲的Postman也没有登录啊,也可以操作成功列出课程之类的,那是因为我们之前讲的案例把教管系统的校验机制给去掉了。现在我们把校验机制打开,然后用Postman发送请求看看会是什么结果

image.png

会看到返回了未登录,假如有效验系统我们该怎么做API测试呢,我们可以在之前加一个登录操作

先看下登录认证API接口文档

用来进行用户登录认证
请求语法

POST /api/mgr/loginReq HTTP/1.1

Host: restapi-teach.com
Content-Type: application/x-www-form-urlencoded

url请求参数

无url请求参数

参数信息 必填 说明
username 必填 填写用户名
password 必填 填写用户密码

响应语法

HTTP/1.1 200 OK
Content-Type: application/json

头部信息

头部信息 必填 说明
Content-Type 必填 该字段值为application/json,表示返回 JSON 格式的文本信息。
Set-Cookie 必填 该字段保存本次登录的sessionid,比如:sessionid=89emkau5vhyg8vcwfwvq2pvr7ul2t5sc

响应内容
如果请求成功,返回json格式的消息体,如下所示,retcode值为0表示登录认证成功

{
    "retcode": 0
}

说明
如果输入的用户名或者密码错误,则返回结果为

{
    "retcode": 1,
    "reason": "用户或者密码错误"
}

我们只要根据这个接口文档,把API接口构建起来

image.png

这样就可以了,登录请求之后响应头里面有个Set-Cookie

image.png

这个值会被Postman保存下来,点击cookies

image.png

他会把当前的网址使用的session存下来

image.png

一旦保存之后,你后续的再进行相关操作就会带上sessionid

此贴部分转载
原文:https://blog.csdn.net/Double2hao/article/details/83744659

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容