当前位置:首页 > 修改聊天记录 > 正文内容

前端安全的输入验证和输出转义最佳实践

前端安全:输入验证 + 输出转义 最佳实践(全网最清晰)

这是前端面试必问、业务必守的安全准则,能直接防御:
XSS 攻击、SQL 注入、命令注入、CSRF、非法数据入侵。
我给你整理成能直接背、能直接用的最佳实践。

一、输入验证(Input Validation)最佳实践

1. 永远不要信任用户输入!

前端所有输入都可被篡改,前端验证只是体验,后端必须二次验证

2. 使用白名单校验(拒绝黑名单)

只允许合法内容,拒绝一切可疑内容
  • 手机号:/^1[3-9]\d{9}$/

  • 邮箱:标准正则

  • 用户名:只允许中文、字母、数字、下划线

  • 禁止输入:< > ' " \ / & * % 等特殊字符

3. 长度限制

所有输入框加最大长度,防止超长攻击、溢出攻击。

4. 数据类型强校验

  • 数字必须是数字

  • 日期必须是日期格式

  • 禁止字符串注入数字字段

5. 禁止直接拼接用户输入到 SQL / HTML / 请求头

这是最危险的行为!

6. 文件上传严格验证

  • 检查文件类型(MIME + 后缀)

  • 检查文件大小

  • 文件重命名存储

  • 上传目录不可执行

7. 框架自带验证优先使用

  • Vue:VeeValidate / Element 校验

  • React:Formik / Yup

  • 原生:HTML5 required pattern

8. 敏感关键词过滤

禁止:script iframe javascript onload onerror alert

二、输出转义(Output Escaping)最佳实践

核心:用户输入渲染到页面时必须转义!
防止 XSS 攻击。

1. HTML 转义(最重要)

把特殊字符转成安全实体:
  • <&lt;

  • >&gt;

  • "&quot;

  • '&#39;

  • &&amp;

2. 不要使用危险 API

禁止:
  • innerHTML

  • document.write

  • v-html(Vue)

  • dangerouslySetInnerHTML(React)

必须用时,必须先转义

3. JS 上下文转义

渲染到 JavaScript 变量时,转义:\ ' " \n \r

4. URL 转义

使用:encodeURIComponent()

5. CSS 转义

过滤:(){}*% 防止 CSS 注入

6. 框架默认安全机制

Vue、React 默认插值表达式是安全的,会自动转义。
危险的是 v-htmldangerouslySetInnerHTML

7. 第三方转义库(推荐)

  • DOMPurify 最安全(XSS 终极防御)


三、前端安全黄金口诀(背会)

  1. 用户输入不可信

  2. 前端验证是体验,后端验证才是安全

  3. 白名单校验,长度限制,类型强校验

  4. 输出必须转义,禁止直接渲染 HTML

  5. 不用 innerHTML、v-html、document.write

  6. 文件上传必须校验类型、大小、重命名

  7. 防御 XSS = 输入过滤 + 输出转义 + 安全渲染


四、极简总结(面试满分答案)

输入验证最佳实践

  1. 不信任任何用户输入,前后端双重校验

  2. 使用白名单规则,限制长度、类型、格式

  3. 过滤特殊字符与敏感关键词

  4. 文件上传严格校验

输出转义最佳实践

  1. 渲染到页面前必须 HTML 转义特殊字符

  2. 禁止使用危险的 HTML 插入 API

  3. 框架默认插值安全,慎用富文本渲染

  4. 使用 DOMPurify 做 XSS 过滤


扫描二维码推送至手机访问。

版权声明:本文由手机数据加工厂发布,如需转载请注明出处。

本文链接:https://gaijilu.com/?id=169

“前端安全的输入验证和输出转义最佳实践” 的相关文章

解密微信数据库文件解析

解密微信数据库文件解析

图解说明:微信大量数据存储在本地比如:联系人(包含好友地区、电话、通过那种方式添加)、聊天内容(图片、文字、语音、视频、位置、名片、其他app分享链接)、聊天室、收藏信息、朋友圈内容(包含好友详情、点赞、评论);摇一摇、附近人、最近联系人、好友请求、图片存放路径;微信内置的表情包;如联系人:聊天信息...

修改微信聊天记录的效果

这个视频是通过软件剪辑合成的,只是表明是这种效果,在实际操作过程中没有这么快捷,有一些准备工作,比方说手机的设置等,手机设置完成连接网络后,可能需要5-10分钟。...

以win10系统为例关闭病毒威胁及防火墙

以win10系统为例关闭病毒威胁及防火墙

关闭病毒威胁及防火墙,按下列步骤流程操作。第1步。在桌面点下图“开始”按钮第2步。在向上弹窗点“齿轮”按钮,然后进入控制面板第3步。在控制面板中点“更新和安全”按钮第4步。安全和中心点“病毒和威胁防护”按钮第5步。病毒和威胁防护“管理设置”按钮第6步。管理设置关闭“实时保护”按钮第7步。点左侧的防火...

为什么你的手机总卡顿?关闭这10个隐藏设置,让你的手机流畅如新

为什么你的手机总卡顿?关闭这10个隐藏设置,让你的手机流畅如新

“家人们,你们有没有这样的体验,半年不到,手机就卡成狗,刷视频,聊微信,一直转圈圈,不管怎么点屏幕都没有任何反应!”最近后台一堆粉丝吐槽:“科普君,新手机像牛奶般丝滑,半年后卡成拖拉机,难道非得换(机)?”别急!今天直接上硬核操作——关闭10个隐藏设置,老机瞬间原地复活!1.关闭 系统自动更新-坑爹...

地震突然来临怎么办?手机上这个设置关键时刻能保命,不同机型方法汇总→

地震突然来临怎么办?手机上这个设置关键时刻能保命,不同机型方法汇总→

今天,甘肃定西市陇西县(北纬34.91度,东经104.58度)发生5.6级地震,震源深度10千米。“中国地震台网”全国地震预警微信小程序向周边49万用户推送了预警信息。如何设置地震预警?地震预警功能非常重要,提前几秒钟的预警都是紧急避险的宝贵时间。如何第一时间接收到地震预警信息?第一步:微信搜索“国...

4 种方法永久保存微信聊天记录,永不丢失

4 种方法永久保存微信聊天记录,永远不会丢方法一:用电脑微信备份(最靠谱、最全)登录电脑版微信,找到备份功能,把手机聊天记录完整存到电脑里。文字、图片、语音、视频、文件全都能保存,不会漏掉。备份好之后,再复制一份存到 U 盘或者移动硬盘里。就算换手机、卸载微信、手机坏掉,记录也能随时找回来。方法二:...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。