Explorar el Código

导出Excel时屏蔽公式,防止CSV注入风险

RuoYi hace 4 años
padre
commit
255101f6f7

+ 9 - 1
ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/utils/poi/ExcelUtil.java

@@ -63,6 +63,8 @@ public class ExcelUtil<T>
63 63
 {
64 64
     private static final Logger log = LoggerFactory.getLogger(ExcelUtil.class);
65 65
 
66
+    public static final String[] FORMULA_STR = { "=", "-", "+", "@" };
67
+
66 68
     /**
67 69
      * Excel sheet最大行数,默认65536
68 70
      */
@@ -589,7 +591,13 @@ public class ExcelUtil<T>
589 591
     {
590 592
         if (ColumnType.STRING == attr.cellType())
591 593
         {
592
-            cell.setCellValue(StringUtils.isNull(value) ? attr.defaultValue() : value + attr.suffix());
594
+            String cellValue = Convert.toStr(value);
595
+            // 对于任何以表达式触发字符 =-+@开头的单元格,直接使用tab字符作为前缀,防止CSV注入。
596
+            if (StringUtils.containsAny(cellValue, FORMULA_STR))
597
+            {
598
+                cellValue = StringUtils.replaceEach(cellValue, FORMULA_STR, new String[] { "\t=", "\t-", "\t+", "\t@" });
599
+            }
600
+            cell.setCellValue(StringUtils.isNull(cellValue) ? attr.defaultValue() : cellValue + attr.suffix());
593 601
         }
594 602
         else if (ColumnType.NUMERIC == attr.cellType())
595 603
         {