DOMPurify 前端富文本 XSS 防护使用指南

DOMPurify 前端富文本 XSS 防护使用指南

安装依赖

使用 npm 安装 DOMPurify 库:

bash 复制代码
npm install dompurify

对于 TypeScript 项目,需额外安装类型声明:

bash 复制代码
npm install @types/dompurify -D
引入库

在项目中引入 DOMPurify:

js 复制代码
import DOMPurify from 'dompurify';
核心净化方法

使用 sanitize 方法对原始 HTML 进行净化:

js 复制代码
const safeHtml = DOMPurify.sanitize(content);
Vue 项目集成

直接使用模板内净化

vue 复制代码
<template>
  <div v-html="DOMPurify.sanitize(content)"></div>
</template>

<script setup>
import { ref } from 'vue'
import DOMPurify from 'dompurify'

const content = ref('<p>博客正文</p><script>恶意脚本</script>')
</script>

使用计算属性优化性能

vue 复制代码
<template>
  <div v-html="safeContent"></div>
</template>

<script setup>
import { ref, computed } from 'vue'
import DOMPurify from 'dompurify'

const content = ref('后端返回的原始富文本')
const safeContent = computed(() => DOMPurify.sanitize(content.value))
</script>
自定义配置

通过配置白名单控制允许的标签和属性:

js 复制代码
const safeContent = computed(() => {
  return DOMPurify.sanitize(content.value, {
    ALLOWED_TAGS: ['p', 'br', 'strong', 'em', 'h1', 'h2', 'ul', 'ol', 'li', 'a', 'img'],
    ALLOWED_ATTR: ['src', 'alt', 'href', 'class', 'title'],
    ALLOW_UNKNOWN_PROTOCOLS: false
  })
})
拦截的 XSS 风险

DOMPurify 自动清除以下恶意内容:

  • <script> 标签
  • 所有内联事件(如 onclick, onerror
  • 危险链接协议(如 javascript:, vbscript:
  • 恶意 iframe 和 svg 注入
安全提醒
  • 禁止直接渲染未净化的 HTML 内容
  • 前端过滤需配合后端二次净化
  • DOMPurify 默认配置已足够安全,无需手动编写正则
核心原则
  • 所有用户输入的 HTML 必须经过净化后才能渲染
  • 净化流程:安装 → 引入 → 调用 sanitize() → 安全渲染
  • 作用:清除恶意脚本,保留合法排版标签
相关推荐
用户新1 天前
JS事件深度解析四 事件的循环和异步
前端·javascript·事件·event loop
广州灵眸科技有限公司1 天前
瑞芯微RV1126B开发板(EASY-EAI-PI2) Easy-Eai编译环境准备与更新
服务器·前端·人工智能·python·深度学习
万少1 天前
我把 Kimi 接进微信,几分钟做了个随手出图助手
前端
xiaofeichaichai1 天前
网络请求与实时通道
前端·网络
kTR2hD1qb1 天前
从 Responses API 到 Chat Completions:一个模型网关的设计复盘
linux·前端
kyriewen1 天前
浏览器缓存最强攻略:强缓存、协商缓存、CDN、更新策略,一篇搞定
前端·面试·浏览器
持敬chijing1 天前
Web渗透之SQL注入-联合查询注入-注入点数据类型判断
前端·sql·安全·web安全·网络安全·安全威胁分析
卷帘依旧1 天前
Web3前端一面
前端
古韵1 天前
告别手写分页逻辑:usePagination 从 50 行到 3 行
java·前端