《前端之路》 之 前端 安全 XSS 原理以及防护手段

什么是 XSS

1、XSS

什么是 XSS

XSS,即 Cross Site Script , 翻译过来就是 跨站脚本攻击;为了和 css 有所区分,于是在安全领域被称为 XSS。javascript

什么是 XSS 攻击

XSS 攻击指的是 攻击者在网站上注入恶意的客户端代码,经过恶意脚本对客户端网页进行篡改,从而在别的用户浏览网页的 时候,对用户进行控制或者获取 用户对隐私数据的 这么一种攻击手段。css

XSS 攻击的方式 是什么

XSS 攻击能够分为3类:反射型(非持久型)、存储型(持久型)、基于DOM。html

XSS攻击须要具有两个条件:须要向web页面注入恶意代码;这些恶意代码可以被浏览器成功的执行。前端

用户注入的 恶意脚本通常包括 JavaScript 、HTML、Flash。不少种的 XSS 攻击方式,可是共同点是: 将一些 隐私数据像:一、cookie、session 发送给攻击者。 二、将受害者重定向到一个由攻击者控制的网站(俗称钓鱼网站),在受害者的机器上进行一些恶意操做。vue

反射型(非持久型)的 XSS 攻击

XSS反射型攻击,恶意代码并无保存在目标网站,而是经过引诱用户点击一个连接到目标网站的恶意连接来实施攻击的。java

直接这么解释仍是有点难懂的。下面,咱们仍是来看个 demonode

<a href="http://127.0.0.1:1212/login/<img src=''  onerror='alert(document.cookie)'>" target="_blank" >这是 XSS 的恶意连接</a>

假设某用户在黑客点钓鱼网站上 点击了这个 带有 XSS 攻击的恶意连接。就会跳转到 http://127.0.0.1:1212 这个网站上。恰好这个路径下的 连接是会有一个 发生一个 get 请求。
那么这个时候 <img src='' onerror='alert(document.cookie)'> 这部分的内容就被 看成 请求的 内容发送给了 服务端。若是服务端 为对该 内容进行 XSS 防护,直接返回给 浏览器。git

那么这个时候就会出现 XSS 攻击了。<img src='' onerror='alert(document.cookie)'> 这句代码被显示在了 浏览器上,由于 img 标签也具备 跨域属性,直接执行了 onerror 中的 JS 代码。 黑客这个时候就能够 在目标网站上 随心所欲了。github

好比这里就是 简单的 alert 了 全部的 cookie。可是,若是我是黑客的话,我确定会把 用户的 cookie、localStorage、等等重要信息 所有上传到个人服务器,而后进行拿到各种想要的信息。从而获益。web

存储型(持久型)的 XSS 攻击

存储型(持久型)的 XSS 攻击 和 反射型 其实也有殊途同归之妙呀。

这么多,我哪里记得住?

别慌,咱们慢慢分析一波就都能记住啦~

恶意代码 经过表单提交的方式 被保存到目标网站的服务器中,这种攻击具备较强的稳定性和持久性,比较常见场景是在博客,论坛、OA、CRM等社交网站上,好比:某CRM系统的客户投诉功能上存在XSS存储型漏洞,黑客提交了恶意攻击代码,当系统管理员查看投诉信息时恶意代码执行,窃取了客户的资料,然而管理员绝不知情,这就是典型的XSS存储型攻击。

咱们仍是写个 demo 来方便 理解吧

<div><textarea id="textarea" class="text"></textarea></div>
    <button id="btn" class="botton">submit</button>

大概就长这个样子了:

textarea 内则为 带有 xss 的代码,点击提交。直接 xhr 请求到 node 的服务端。

node 服务端 接收到 传入的参数 不作任何 xss 防护 直接保存起来的 js demo
通常是存储 sql 可是这里方便起见 咱们就直接存 memory-cache ,代码以下:

router.post("/upload", (ctx, next) => {
  let curData = JSON.stringify(ctx.request.body);
  cache.put("xss", curData);
  ctx.body = `<div>${curData}</div>`;
});

咱们请求 一个新的路径来将 memory-cache 的值获取到。 node 端 代码:

router.get("/getName", (ctx, next) => {
  let curData = cache.get("xss");
  ctx.body = `<div>${JSON.parse(curData)}</div>`;
});

接下来就是访问 http://127.0.0.1:1212/getName

获得 以下 画面:

固然,黑客不会 alert 你的 cookie 信息。 直接 post 到 一个第三方的 服务器上,而后直接模拟浏览器访问,那就简直了。

基于 DOM 的 XSS 攻击

基于 DOM 的 XSS 攻击是指经过恶意脚本修改页面的 DOM 结构,是纯粹发生在客户端的攻击。

const divXss = document.getElementById("xss");
    const xssbtn = document.getElementById("xssbtn");

    const val = `'' onclick=alert(/xss/)`;

    xssbtn.addEventListener("click", function() {
      divXss.innerHTML = `<a href=${val}>testLink</a>`;
    });

固然上面的这个 val 每每是黑客 经过 input 或者 textarea 的 form表单提交引发的

当用户下意识的去点击 这个新增的 dom 的时候,就会出现 以下 场景:

黑客又能够随心所欲了。

2、XSS 的 防护

HttpOnly 最先由微软提出,至今已经成为一个标准。浏览器将禁止页面的Javascript 经过 document.cookie 获取带有 HttpOnly 属性的Cookie。

上文有说到,攻击者能够经过注入恶意脚本获取用户的 Cookie 信息。一般 Cookie 中都包含了用户的登陆凭证信息,攻击者在获取到 Cookie 以后,则能够发起 Cookie 劫持攻击。因此,严格来讲,HttpOnly 并不是阻止 XSS 攻击,而是能阻止 XSS 攻击后的 Cookie 劫持攻击。

输入检查

不要相信用户的任何输入。 对于用户的任何输入要进行检查、过滤和转义。创建可信任的字符和 HTML 标签白名单,对于不在白名单之列的字符或者标签进行过滤或编码。

在 XSS 防护中,输入检查通常是检查用户输入的数据中是否包含 <,> 等特殊字符,若是存在,则对特殊字符进行过滤或编码,这种方式也称为 XSS Filter。

而在一些前端框架中,都会有一份 decodingMap, 用于对用户输入所包含的特殊字符或标签进行编码或过滤,如 <,>,script,防止 XSS 攻击:

// vuejs 中的 decodingMap
// 在 vuejs 中,若是输入带 script 标签的内容,会直接过滤掉
const decodingMap = {
'<': '<',
'>': '>',
'"': '"',
'&': '&',
' ': '\n'
}

输出检查

用户的输入会存在问题,服务端的输出也会存在问题。通常来讲,除富文本的输出外,在变量输出到 HTML 页面时,可使用编码或转义的方式来防护 XSS 攻击。

例如利用 sanitize-html 对输出内容进行有规则的过滤以后再输出到页面中。

本 demo 中的 koa 框架其实在输出的时候处理了标签:

这个时候 就会 减小 99% 的 xss 攻击了。是否是发现选择一款好的框架能节省好多的麻烦。

好了,这篇关于 XSS 的文章就介绍到 这里了,别着急 源码会放出来的。

全文的 demo 的源码地址: github源码地址

总结

一旦在DOM解析过程成出现不在预期内的改变,就有可能发生 XSS。
失控 就会出现 BUG。
防护手段 既然 攻防的人都知道了,那么自身代码的严谨程度就决定了整个项目的安度。
忽然想起了 PDD ...

GitHub 地址:(欢迎 star 、欢迎推荐 : )

前端 安全 XSS 原理以及防护手段

相关文章
相关标签/搜索