0

0

怎样进行JavaScript安全编码_常见的XSS和CSRF如何防御

幻影之瞳

幻影之瞳

发布时间:2025-12-24 16:56:58

|

350人浏览过

|

来源于php中文网

原创

怎样进行javascript安全编码_常见的xss和csrf如何防御

JavaScript安全编码的核心是不信任任何外部输入,对用户数据做严格过滤和转义,同时利用现代浏览器机制隔离执行环境。XSS和CSRF是Web前端最常见、危害最大的两类攻击,防御需从前端、后端协同入手,不能只靠单侧措施。

防范XSS:从输出上下文决定转义方式

XSS本质是恶意脚本被当作HTML/JS/CSS执行。关键不是“过滤输入”,而是“在输出时按上下文正确转义”:

  • HTML内容中插入用户数据:用textContent代替innerHTML;若必须用innerHTML,先通过DOMPurify等库清理HTML,不自己写正则过滤
  • HTML属性中插入数据:如
    ,需对双引号、尖括号、&等字符做HTML实体编码(", zuojiankuohaophpcn, &
  • JavaScript字符串中嵌入数据:如var name = "USER_INPUT";,必须用JSON序列化(JSON.stringify()),不要拼接字符串
  • URL参数中插入数据:用encodeURIComponent(),避免直接拼进hrefsrc
  • 阻断CSRF:服务端验证 + 前端配合

    CSRF利用用户已登录状态发起非授权请求,防御重点是确认“这个请求确实是用户本意发出的”:

    • 后端必须校验CSRF Token:为每个会话生成唯一Token,表单提交或AJAX请求时带上(如放在header X-CSRF-Token 或 body字段),后端比对并一次性使用
    • 前端正确携带Token:登录成功后从响应头或接口获取Token,存在sessionStorage;所有敏感请求(POST/PUT/DELETE)自动注入Token,可用Axios拦截器统一处理
    • 合理使用SameSite Cookie属性:将身份Cookie设为SameSite=Lax(默认现代浏览器行为),可拦截大部分跨站POST请求;敏感操作进一步设为Strict
    • 避免GET请求修改状态:删除、支付、权限变更等操作禁用GET,防止被图片链接、重定向等方式触发

    增强JavaScript运行时防护

    即使有基础防御,也要减少攻击面和提升容错能力:

    LangChain
    LangChain

    一个开源框架,用于构建基于大型语言模型(LLM)的应用程序。

    下载

    立即学习Java免费学习笔记(深入)”;

    • 启用CSP(Content Security Policy):通过HTTP响应头Content-Security-Policy限制脚本来源,禁止eval、内联脚本和未授权域名加载,大幅降低XSS危害
    • 避免危险API滥用:禁用eval()Function()setTimeout(string)setInterval(string);用JSON.parse()代替eval()解析JSON
    • 敏感操作二次确认:删除账户、转账、修改邮箱等关键动作,前端弹窗确认+后端再次校验Token和用户意图(如短信/邮箱验证码)
    • 最小权限原则:前端仅请求必要数据,避免暴露敏感字段(如token、密码哈希)到全局变量或console日志

    安全不是功能开关,而是贯穿开发流程的习惯。每次拼接用户数据前问一句“它会在哪里被解释执行”,每次发请求前确认“服务端是否验证了身份和意图”。不复杂但容易忽略。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

536

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

372

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

706

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

470

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

388

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

989

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

652

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

535

2023.09.20

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.7万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.5万人学习

CSS教程
CSS教程

共754课时 | 16.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号