JavaScript防止代码注入方法解析
时间:2026-03-17 08:29:29 120浏览 收藏
JavaScript本身无法主动防御代码注入,真正的防护关键在于彻底杜绝将不可信字符串当作代码执行——禁用eval()、Function()、setTimeout(string)等危险函数,优先使用textContent处理文本、DOMPurify或转义机制处理HTML插入,并严格采用JSON.parse()解析数据;同时配合CSP策略禁用'unsafe-eval'和'unsafe-inline',从源头切断XSS与代码注入的执行路径。

JavaScript本身不能直接防止代码注入攻击,关键在于不执行不可信的字符串作为代码。常见错误是用eval()、Function()、setTimeout(string)或setInterval(string)动态运行用户输入的内容。
避免动态执行字符串代码
这是最核心的防护原则。任何来自用户、URL参数、表单、API响应或本地存储的数据,都不能直接传给以下函数:
eval()new Function(...)setTimeout(string, ...)或setInterval(string, ...)document.write()(尤其拼接用户数据时)
例如,不要这样写:
❌ 错误示例const userInput = 'alert("xss")';
eval(userInput); // 危险!
安全处理HTML和DOM插入
向页面插入用户内容时,必须防止XSS(跨站脚本)——本质也是一种代码注入。
- 用
textContent代替innerHTML,当只需显示纯文本时 - 若必须插入HTML,先对特殊字符做转义(如
<→<),或使用可信的库如DOMPurify - 避免用字符串拼接构造HTML,改用
document.createElement()+appendChild()+textContent
例如:
✅ 推荐方式const el = document.createElement('div');
el.textContent = userInput; // 自动转义,安全
谨慎使用JSON解析与模板引擎
JSON.parse()本身安全(只要输入是合法JSON),但注意别用eval()模拟解析;模板引擎如Handlebars、Mustache默认会自动转义变量,但需确认未关闭转义(如Handlebars中{{{ }}}是不转义的,慎用)。
- 永远用
JSON.parse(),不用eval('(' + jsonStr + ')') - 检查模板语法是否启用了“原始输出”,避免把用户数据不经转义渲染成HTML
- 服务端返回的数据,前端仍需当作不可信内容处理,不因“自己后端发的”就放松校验
启用CSP(内容安全策略)作为纵深防御
CSP不是JS代码层面的修复,但能大幅降低注入成功后的危害。通过HTTP响应头设置:
Content-Security-Policy: default-src 'self'; script-src 'self' 'unsafe-inline' 'unsafe-eval'
应移除'unsafe-eval'和'unsafe-inline',改用外部JS文件和事件委托。
- 禁止内联脚本(
、onclick="...") - 禁止
eval类函数执行 - 配合非ces-only的哈希或nonce机制更稳妥
以上就是《JavaScript防止代码注入方法解析》的详细内容,更多关于的资料请关注golang学习网公众号!
相关阅读
更多>
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
308 收藏
-
368 收藏
-
370 收藏
-
478 收藏
-
402 收藏
-
379 收藏
-
456 收藏
-
134 收藏
-
492 收藏
-
156 收藏
-
399 收藏
-
281 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习