什么是会话固定攻击(Session Fixation)?

你知道吗?登录网站时,网站是怎么记住你身份的?答案就是会话(Session)。

可以把 Session 想象成住酒店拿到的房卡。拿着这张卡,酒店就知道你是哪个房间的客人,能进出房间、使用配套设施。但如果这张房卡被人动了手脚呢?

打个比方:你参加旅行团,导游帮所有人办入住,发给你一张 302 号房的房卡。你刷卡进门,一切正常,可你不知道导游手里还有一张一模一样的房卡。你入住后,他随时能打开你的房门 —— 这就是会话固定攻击(Session Fixation)的核心逻辑。

简单说:黑客提前准备好一个会话 ID,想方设法让你用这个 ID 登录。你登录成功后,黑客用同一个 ID 就能冒充你的身份,接管你的账号。

先搞懂:什么是 Session?

网页本身是 “无状态” 的。简单讲,你每次给网站发请求,对网站来说都是 “陌生人”—— 它不会自动记住你刚登录过、购物车里加过商品。

要是没有 Session,每换一个页面就得重新登录,购物车内容也会清空,体验极差。所以网站需要 Session 机制,用来记住用户身份和操作状态。

Session 的正常运作流程

  1. 用户提交登录信息:输入账号密码,点击登录,浏览器把信息发给服务器。
  2. 服务器生成会话 ID:验证账号密码正确后,服务器生成唯一的
  3. 会话 ID(Session ID),把这个 ID 和你的身份信息绑定,存在服务器里。
  4. 服务器把 ID 发给浏览器:服务器返回网页时,会在 HTTP 响应头里加Set-Cookie字段,把 Session ID 写进去,比如Set-Cookie: session_id=abc123xyz789。浏览器收到后,会自动把这个 ID 存到 Cookie 里,全程不用用户操作。
  5. 后续请求自动带 ID:之后浏览网站其他页面时,浏览器会自动把 Cookie 里的 Session ID 放进请求里发给服务器。服务器核对 ID,就能认出 “这是某某用户”,实现记住登录状态的效果。

会话固定攻击:黑客是怎么动手的?

这种攻击涉及三方:攻击者(黑客)、受害者(普通用户)、存在漏洞的网站。核心漏洞是:网站在用户登录后,没有更换新的 Session ID,继续沿用登录前的旧 ID。

完整攻击步骤

第一步:黑客获取一个空白 Session ID

黑客先正常访问目标网站。很多网站为了支持 “未登录也能浏览商品、加购物车”,会在用户刚进入网站时,就分配一个空白 Session ID—— 这个 ID 此时没绑定任何身份,只是临时标识。

黑客拿到这个 ID(比如abc123),记下来备用。

第二步:黑客把这个 ID “塞给” 受害者

黑客制作一个带 Session ID 的恶意链接,链接看起来和正常网站地址没区别,只是末尾加了 Session ID 参数,比如:https://example.com/login?sid=abc123。

接着黑客通过钓鱼邮件、短信、社交软件把链接发给受害者,附上当理由话术,比如 “你的账号有异常,点击链接核实身份”“免费领取福利,点击登录领取”。

第三步:受害者中招,使用黑客指定的 ID

受害者没警惕心,点击恶意链接。浏览器向网站发请求,请求地址里带着黑客写的sid=abc123。

有漏洞的网站会接受 URL 里的 Session ID,直接把abc123设为受害者的 Session ID,还会通过Set-Cookie把这个 ID 存到受害者浏览器的 Cookie 里。

之后受害者在登录页输入自己的账号密码,成功登录。

第四步:关键漏洞 —— 网站不更换 Session ID

正常网站在用户登录(权限从游客变成会员)后,会立刻作废旧 ID、生成新 ID。但漏洞网站会继续用原来的abc123,并把受害者的身份和这个 ID 绑定。

此时,abc123从空白 ID 变成了 “绑定受害者账号” 的有效 ID,而这个 ID,黑客早就知道。

第五步:黑客用同一个 ID 冒充受害者

黑客把abc123存到自己浏览器的 Cookie 里,访问目标网站。服务器收到请求后,核对 Session ID,发现abc123对应受害者的登录状态,就会把黑客当成受害者。

黑客不需要知道受害者的账号密码,就能直接进入受害者账号,查看个人信息、交易记录,甚至进行转账、下单、改密码等操作。

会话固定攻击有哪些危害?

一旦攻击成功,黑客能完全控制受害者账号,造成多种严重后果:

  1. 窃取隐私信息:查看个人资料、聊天记录、订单信息、绑定的手机号和邮箱等敏感内容。
  2. 发起未授权操作:以受害者名义在电商平台下单、支付,在社交账号发不良言论,在银行类网站转账。
  3. 永久接管账号:修改受害者的账号密码、绑定手机和邮箱,让受害者无法登录自己的账号,彻底失去账号控制权。

如何防范会话固定攻击?

攻击的核心是 “登录前后共用同一个 Session ID”,防护思路很明确:破坏这个共用逻辑,核心有 3 点:

1. 登录成功后,必须重新生成 Session ID(最关键)

用户登录、权限提升时,服务器要做两件事:作废旧 Session ID、生成全新的随机 Session ID,再把新 ID 发给浏览器。

这一步叫 “会话再生(Session Regeneration)”,主流开发框架(如 Java Spring、Python Django、PHP Laravel)都内置了这个功能,开发者只需在登录成功后调用对应函数即可。只要做到这一点,黑客手里的旧 ID 会直接失效,攻击无法成功。

2. 拒绝从 URL、表单获取 Session ID

很多网站早期为兼容不支持 Cookie 的浏览器,会允许从 URL 参数、表单隐藏字段读取 Session ID,这是高危漏洞。

正确做法:只接受 Cookie 里的 Session ID,拒绝 URL、表单传来的 ID,从根源上杜绝黑客通过恶意链接植入 ID 的可能。

3. 给 Cookie 设置安全属性

Session ID 存在 Cookie 里,给 Cookie 加安全属性,能进一步降低风险:

  • HttpOnly:禁止 JavaScript 读取 Cookie,防止跨站脚本攻击(XSS)窃取 Session ID。
  • Secure:Cookie 仅在 HTTPS 加密连接中传输,避免中间人攻击拦截 ID。
  • SameSite:限制 Cookie 跨站传输,防范跨站请求伪造攻击(CSRF)。

总之,会话固定攻击,本质是黑客提前固定一个 Session ID,诱导受害者使用该 ID 登录,再用同一 ID 冒充受害者。它和会话劫持(Session Hijacking)不同:劫持是 “偷” 用户已有的 Session ID,固定攻击是 “给” 用户一个黑客已知的 ID。

对开发者来说,防护核心只有一句话:用户登录后,务必重新生成 Session ID。再配合 “拒绝 URL 传 ID、设置 Cookie 安全属性”,就能彻底防范这类攻击,守住用户账号安全。

原创文章,作者:余初云,如若转载,请注明出处:https://blog.jidcy.com/jsjc/2701.html

Like (1)
Previous 2026年5月18日 上午10:42
Next 2026年5月19日 上午11:39

相关推荐

  • 云计算核心技术:准虚拟化是什么意思?

    虚拟化是驱动全球数字基础设施的核心理念和技术。从虚拟桌面到云端虚拟机,虚拟化最大化了物理硬件和软件资源的利用率,惠及众多行业。 准虚拟化是虚拟化的一种形式,许多专家认为它是该技术中…

    2026年4月29日
    0
  • 如何在 Ubuntu 22.04 和 24.04 上安装 Git

    Git 可在 Ubuntu 默认的 22.04 LTS 和 24.04 版本中直接安装,因此安装过程非常快捷。较为复杂的部分是配置 GitHub 或 GitLab 的 SSH 密钥…

    2026年3月27日
    0
  • 拒绝服务攻击 DoS 与 DDoS 解析

    在网络安全领域,DoS 和 DDoS 是两类高频且危害显著的攻击方式,二者核心目的都是让目标网络或服务器无法正常提供服务,但攻击模式、破坏力和应对难度截然不同。 DoS,即拒绝服务…

    2026年5月18日
    0
  • 如何在服务器上安装 PHP(Linux / Windows / macOS)

    这篇文章会带你在 Linux、Windows 和 macOS 三个系统上完成 PHP 的安装,并介绍如何与 Apache 或 Nginx 配合使用、安装常用扩展,以及验证安装是否成…

    2026年4月20日
    0
  • 常听到的边缘缓存是什么意思?

    简单来说,边缘缓存就是把内容存到离终端用户最近的网络边缘节点上的一种技术。 当用户就近访问这些边缘缓存里的数据时,会比从遥远的地方获取数据高效得多。这种额外的效率,最终能减轻整个网…

    2026年4月22日
    0
  • SQL 与 NoSQL 数据库对比:该怎么选?

    NoSQL 数据库凭借易用、好开发、扩展性强等特点,一直备受认可。在处理海量数据时速度快、使用灵活,如今在大数据和实时互联网应用中越来越普及。 但这不代表任何场景都适合换成 NoS…

    2026年4月22日
    0
  • SQL Server 性能调优如何做?

    SQL 服务器性能调优,本质上是寻找更高效的方式处理相同工作负载。本文将详细探讨 SQL 性能调优的定义、必要性,以及可落地的方法。 什么是 SQL Server 性能调优? SQ…

    2026年4月24日
    0
  • 如何修复 DNS_PROBE_FINISHED_NXDOMAIN 错误

    当浏览器找不到网站的 IP 地址时,会出现 DNS_PROBE_FINISHED_NXDOMAIN 错误。简单来说,域名的解析不正常。 如果你遇到这个错误,请先尝试以下快速修复方法…

    2026年3月26日
    0
  • 异步api是什么?与REST API的区别

    当今用户对实时信息的需求日益强烈,股价、列车时刻等数据都需要在发生的第一时间送达。如何实时推送这些关键信息,是每家企业面临的共同挑战。传统做法是让应用定期轮询后端服务器来获取最新数…

    2026年4月11日
    0
  • 什么是点对点协议(PPP)?

    互联网依赖于许多通信规则,即协议,在设备之间移动数据。PPP (Point-to-Point Protocol,点对点协议)是早期最重要的直接连接协议之一。 PPP允许两台设备在一…

    2026年4月13日
    0