news 2026/5/14 10:22:15

浏览器本地存储Cookie, local/sessionStorage - Token结合Cookie实现登录管理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
浏览器本地存储Cookie, local/sessionStorage - Token结合Cookie实现登录管理

不需要走网络、不会影响资源的加载流程

Cookie

Cookie 是浏览器用来存储少量文本数据的小型文件 (≤ 4KB),每次发送请求的时候都会自动携带和这个域名关联的 Cookie,主要用于例如

会话管理(Session ID)、登录状态(SSO):方便服务器端识别是谁

个性化设置,如

theme=dark language=zh

跨站跟踪,例如页面中嵌入了广告商的 img ,广告商域名会设置自己的 Cookie ,当访问另一个同域的网站时就能识别出是同一个用户

内容

Cookie 存储在浏览器内部,每个域名都有自己Cookie的

  • 名称
  • 过期时间
  • 安全属性

浏览器会自动管理它们,开发者无法指定目录存放位置

生命周期

Cookie有两种

1. 会话 Cookie ( Session Cookie )

没有设置 expires 或max-age,当浏览器关闭时自动删除

2. 持久化 Cookie ( Persistent Cookie )

设置了过期时间,到时候会自动删除,例如

Set-Cookie: token=abc123; Max-Age=3600

Max-Age 的单位是 秒 ,表示一个小时后自动删除

Cookie 是如何跟随请求的

例如服务器创建Cookie并返回

Set-Cookie: session_id=xyz; HttpOnly; Secure; Path=/;

那么浏览器自动存储和管理,之后访问同域名页面时会自动携带

Cookie: session_id=xyz

安全隐患

Cookie 被偷走或者滥用都是无感的

1. XSS

在页面中注入 JS ,读取

document.cookie

但是不能读 HttpOnly 的:开启后只能服务器使用、防止JS读Cookie

如果被读到了 session_id 或 token 那登录态就泄露了,对方可以直接设置同样的 Cookie 然后伪装身份进行登录,即会话挟持

2. CSRF

利用请求同域时会自动带上Cookie的特性

例如之前你登录过 bank.com ,后面你不小心点击了 bank.com/transer 导致能拿到你的 Cookie 然后识别你的身份进行了操作

  1. 可以通过设置SameSite = Strict任何跨站都不带 Cookie,

    或者设置为Lax,那么跳转进来是可以携带的

  2. 在敏感信息上设置一个隐藏的随机 token ,例如

    <input type = "hidden" name = "csrf_token" value = "xxxx">

    每次 POST/操作请求 都必须带上这个 token,服务器验证 token 是否匹配、是否过期

重要属性

1. secure

确保 Cookie 只能在 HTTPS下传输,防止 HTTP 明文环境被窃听

2. HttpOnly

3. SameSite

4. Path

指定 Cookie 作用的路径,例如 Path=/a 那么只有在 /a 时会发送 Cookie

5. Domain

限制 Cookie 生效范围

例如设置了 Domain = k.com,

那么 a.k.com 和 b.k.com 都能拿到

Token结合Cookie实现登录管理

1. 长短期双Token - 前后端分离

短期令牌 Access Token 放在前端例如 localStorage 中

长期令牌 Refresh Token 放在 HttpOnly Cookie 中供服务器端使用(防XSS),且开启 Secure

  1. 登录

    1. 前端发送 POST 请求
    2. 服务器验证成功后返回 长期令牌
    Set-Cookie: refresh_token=xxx; HttpOnly; Secure; SameSite=Lax; Max-Age=7d

    浏览器自动放到 Cookie 中;

    并在 响应体 中返回 短期令牌

    { "access_token": "xxx", "expire_in": 900 }

    前端保存到内存(JS变量)或者 localStorage 中

  2. 调用业务 API 时,请求手动携带 Access Token

    GET /api/userinfo Authorization: Bearer ACCESS_TOKEN
    1. 没有过期的话直接服务器验证然后返回
    2. 如果服务器返回401表示短期令牌 Access Token 过期了,那么前端立即调用 POST /api/refresh_token 携带上 长期令牌 refresh_token 去请求,服务器端验证长期令牌成功后会在响应体中返回新的 短期令牌 ,前端更新 Access Token
    3. 如果返回403表示长期令牌也过期了,那么就需要重新登录

2. 所有 Token 都放在 HttpOnly Cookie 中

  1. 在登录后服务器返回 Cookie
  2. 前端访问 API 的时候,不用手动个携带信息(Cookie请求时自动携带了
  3. 后端直接从 Cookie 中读取 token 进行验证

需要注意 CSRF ,得打开 SameSite 为 Strict 或 Lax

3. 传统 Session 模式

Cookie 只存 sessionId , Token 由服务器端管理

  1. 登录后服务器返回 Cookie 是 SessionId
  2. 前端每次请求都会携带这个 SessionId Cookie

如果 Cookie 是 Session 会话级的,那么页面关闭就需要再次登录请求

如果是 持久化 Cookie 的话就看过期时间

SSO单点登录 - cookie

浏览器端自动附带凭证的唯一可靠机制就是 Cookie浏览器不会自动携带 localStorage 、sessionStorage、IndexedDB 的数据

4KB

所以要实现自动登陆、无感跳转本质就只有 Cookie 能进行验证

开启 SameSite = None; Secure

localStorage、SessionStorage

5MB

是浏览器暴露给 JS 的持久化存储方式,通过键值对形式进行管理,属于 Web Storage ,无法像缓存一样参与资源加载

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/13 11:02:23

numba,让你的Python飞起来!

python由于它动态解释性语言的特性&#xff0c;跑起代码来相比java、c要慢很多&#xff0c;尤其在做科学计算的时候&#xff0c;十亿百亿级别的运算&#xff0c;让python的这种劣势更加凸显。办法永远比困难多&#xff0c;numba就是解决python慢的一大利器&#xff0c;可以让py…

作者头像 李华
网站建设 2026/5/10 23:40:20

GPT-5.2超强功能全解析:这几个改变让你工作更高效,赶快体验!

如果你也是GPT的忠实粉丝&#xff0c;那么你一定知道&#xff0c;GPT-5的更新版——GPT-5.2已经登场了&#xff01;和之前的版本相比&#xff0c;GPT-5.2不仅做了很多优化&#xff0c;还加入了一些超级酷的新功能。可以说&#xff0c;它在各个方面都提升了工作效率和用户体验&a…

作者头像 李华
网站建设 2026/5/10 23:29:28

9 款工具:科研人写开题报告,该怎么选对 AI 辅助工具?

在 CSDN 社区里&#xff0c;开题报告是科研新人绕不开的 “第一关”—— 格式不对、逻辑松散、文献难凑&#xff0c;每一个都能卡半天。现在 AI 工具越来越多&#xff0c;但 “哪个工具适配工科&#xff1f;哪个能同步院校模板&#xff1f;” 却没清晰的答案。今天从paperxieAI…

作者头像 李华
网站建设 2026/5/11 0:41:51

我的错题冰雹数

nint(input()) max10 for j in range(2,n1):numjwhile num!1:if num%20:numnum//2else:num3*num1if num>max1:max1numif num<j:break print(max1)题目任意给定一个正整数 NN&#xff0c;如果是偶数&#xff0c;执行&#xff1a; N/2N/2&#xff1b;如果是奇数&#xff0c…

作者头像 李华
网站建设 2026/5/6 17:23:10

Linux 有名管道fifo进程间通信

函数原型/*** int mkfifo(const char *pathname, mode_t mode);* * brief 用于创建有名管道。该函数可以创建一个路径为pathname的FIFO专用文件&#xff0c;mode指定了FIFO的权限&#xff0c;FIFO的权限和它绑定的文件是一致的。FIFO和pipe唯一的区别在于创建方式的差异。一旦创…

作者头像 李华
网站建设 2026/5/9 7:37:55

TikTok直播录制全攻略:从入门到精通的完整解决方案

在内容创作蓬勃发展的今天&#xff0c;TikTok直播已成为创作者与粉丝深度互动的重要渠道。然而&#xff0c;直播内容的即时性往往让精彩瞬间转瞬即逝&#xff0c;让无数用户深感遗憾。现在&#xff0c;一款强大的开源录制工具横空出世&#xff0c;完美解决了这一痛点&#xff0…

作者头像 李华