最全--跨站脚本攻击(XSS)举例和预防方法

XSS定义

跨站脚本攻击(XSS)是指攻击者通过在网页中注入恶意脚本 srcipt ,进而在用户浏览该网页时执行恶意脚本,从而窃取用户信息、篡改网页内容等。总之:安全无小事,需要前后端等同学都预防,默认不信任数据

不安全的数据来源

  • 假设来源不一定安全,那么需要进行转义。
    • URL查询参数
    • 后台数据库(接口)返回值
    • 用户在当前页面的输入内容
  • 假设来源安全(内存临时变量),那么大概率安全,也要进行判断。

一、HTML相关

1、避免使用.innerHTML.outerHTML

当从URL查询参数中取值并未经过转义处理直接使用时,攻击者可以在URL中添加恶意脚本,使其在用户访问时被执行。

html 复制代码
<div id="content"></div>
<script>
    var content = document.getElementById("content");
    var name = new URLSearchParams(window.location.search).get("name");
    content.innerHTML = "Hello, " + name;
    // 解决办法:使用`.innerText`或`.textContent`替代`.innerHTML`和`.outerHTML` 或者其他转义方法
</script>

1.2 解释

在上述代码中,从URL查询参数中获取name值,并直接将其插入到页面中,未经过转义处理。攻击者可以在URL中添加恶意脚本,例如:?name=<script>alert('XSS')</script>,当用户访问该URL时,恶意脚本将被执行。

2、避免使用document.write()

避免使用document.write(),改用其他DOM操作方法,如createElementappendChild等。

html 复制代码
<div id="content"></div>
<script>
    var content = document.getElementById("content");
    var userInput = "<script>alert('XSS');</script>";
    // 错误写法 document.write(userInput);
    var textNode = document.createTextNode(userInput);
    content.appendChild(textNode);
</script>

3、使用.setAttribute()前要判断

当使用.setAttribute()为元素设置属性时,确保属性值不包含恶意脚本

html 复制代码
<a id="link" href="#">Click me</a>
<script>
    var link = document.getElementById("link");
    var userInput = "javascript:alert('XSS');";
    // 错误写法 link.setAttribute("href", userInput);
    if (!/^javascript:/i.test(userInput)) {
        link.setAttribute("href", userInput);
    }
</script>

4、使用Vue.js中的v-html之前要判断

Vue.js中避免使用v-html指令插入不可信的动态内容。如有必要,可以使用第三方库(如DOMPurify)对内容进行清理。

html 复制代码
<div id="app">
    <div v-html="cleanedUserInput"></div>
</div>
<script>
    new Vue({
        el: "#app",
        computed: {
            cleanedUserInput: function() {
                return DOMPurify.sanitize(this.userInput);
            }
        },
        data: {
            userInput: "<script>alert('XSS');</script>"
        }
    });
</script>

二、JavaScript相关

eval()setTimeout()setInterval()都可以执行JavaScript代码,当这些函数的参数是用户可控的输入时,可能会引入安全风险,尤其是跨站脚本攻击(XSS)。

1. eval()

javascript 复制代码
var userInput = "alert('XSS');";
// 错误写法 eval(userInput);
避免使用`eval()`,尽量使用其他安全的方法来实现需求

2.setTimeout()

javascript 复制代码
var userInput = "alert('XSS');";
// 错误写法 setTimeout(userInput, 1000);
解决办法:使用函数作为`setTimeout()`的第一个参数,而不是字符串。
setTimeout(function() {
    alert('Safe code');
}, 1000);

3.setInterval()

与 setTimeout() 相同

三、与后台相关

对用户提交的数据进行过滤和转义。示例:攻击者在评论系统中提交带有恶意脚本的评论,例如<script>alert('XSS');</script>,当其他用户查看评论时,恶意脚本被执行。 解决办法:在存储用户提交的数据之前,对其进行过滤和转义。可以使用专门的转义函数或库,如escapeHTML()DOMPurify等。另外如果数据库被恶意写入数据,那么也会导致前端不安全。

四、第三方库和插件

示例:使用了一个存在XSS漏洞的富文本编辑器。 解决办法:使用安全的第三方库和插件,并确保及时更新以修复已知漏洞。

相关推荐
kyriewen9 分钟前
我读了一遍 Babel 编译后的 async/await,终于搞懂了它的原理(附 20 行手写实现)
前端·javascript·面试
IT_陈寒37 分钟前
Vite项目build后路由404了?你可能漏了这个小配置
前端·人工智能·后端
lichenyang45343 分钟前
AI 聊天从纯文本到结构化卡片:SSE done 帧携带 card + 历史记录卡片恢复实战
前端
梦曦i1 小时前
@meng-xi/vite-plugin v0.1.5:告别手动 import,精简工具层
前端
梦曦i1 小时前
Vite 0.1.6重磅更新:智能导入+路由安全
前端
gxf5203088069882 小时前
Flutter 裁剪图片
前端·app
ITMan彪叔2 小时前
赋能UE运行态编辑平台: 网络图片下载的插件改造与复盘
前端
RANxy2 小时前
🚀 Umi Max 项目从0到1:企业级 React 脚手架实战
前端·前端框架
拾年2752 小时前
深入理解 V8 引擎:从代码执行到垃圾回收的完整链路
前端·javascript·v8
zzz_23683 小时前
【RabbitMQ】面试系列 · 第三期:从线上故障到架构选型
面试·架构·rabbitmq