From 66a8572ed67f9a4fbcd965e8c8a6504abfe4ddb2 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?=E5=90=AC=E6=B5=B7?= <445436867@qq.com>
Date: Mon, 21 Oct 2024 15:42:03 +0800
Subject: [PATCH] =?UTF-8?q?feat:=20=E4=BF=AE=E5=A4=8Dxss=E6=BC=8F=E6=B4=9E?=
=?UTF-8?q?=20(#254)?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
packages/fes-plugin-layout/package.json | 1 +
.../fes-plugin-layout/src/runtime/helpers/svg.js | 4 +++-
.../fes-plugin-layout/src/runtime/views/MenuIcon.vue | 12 +++++++-----
packages/fes-template/src/app.jsx | 2 +-
pnpm-lock.yaml | 7 +++++++
5 files changed, 19 insertions(+), 7 deletions(-)
diff --git a/packages/fes-plugin-layout/package.json b/packages/fes-plugin-layout/package.json
index 4b312200..fd9e83dc 100644
--- a/packages/fes-plugin-layout/package.json
+++ b/packages/fes-plugin-layout/package.json
@@ -30,6 +30,7 @@
"peerDependencies": {
"@fesjs/fes": "^3.1.13",
"@fesjs/fes-design": ">=0.7.0",
+ "dompurify": "^3.1.7",
"vue": "^3.2.47",
"vue-router": "^4.0.1"
},
diff --git a/packages/fes-plugin-layout/src/runtime/helpers/svg.js b/packages/fes-plugin-layout/src/runtime/helpers/svg.js
index 54ea0491..e2109569 100644
--- a/packages/fes-plugin-layout/src/runtime/helpers/svg.js
+++ b/packages/fes-plugin-layout/src/runtime/helpers/svg.js
@@ -1,3 +1,5 @@
+import DOMPurify from 'dompurify';
+
const isStr = function (str) {
return typeof str === 'string';
};
@@ -26,7 +28,7 @@ export function isValid(elm) {
export function validateContent(svgContent) {
const div = document.createElement('div');
- div.innerHTML = svgContent;
+ div.innerHTML = DOMPurify.sanitize(svgContent);
// setup this way to ensure it works on our buddy IE
for (let i = div.childNodes.length - 1; i >= 0; i--) {
diff --git a/packages/fes-plugin-layout/src/runtime/views/MenuIcon.vue b/packages/fes-plugin-layout/src/runtime/views/MenuIcon.vue
index eef3800c..a6320418 100644
--- a/packages/fes-plugin-layout/src/runtime/views/MenuIcon.vue
+++ b/packages/fes-plugin-layout/src/runtime/views/MenuIcon.vue
@@ -1,11 +1,11 @@
+