From 24ae7de61dd2cd1a6fcdd97b88ef9fdfbb795306 Mon Sep 17 00:00:00 2001 From: RuoYi Date: Fri, 10 Aug 2018 18:12:28 +0800 Subject: [PATCH] =?UTF-8?q?=E6=96=B0=E5=A2=9Exss=E8=BF=87=E6=BB=A4?= =?UTF-8?q?=E5=BC=80=E5=85=B3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/com/ruoyi/common/xss/XssFilter.java | 22 +++++++++++++++---- .../ruoyi/framework/config/FilterConfig.java | 3 ++- 2 files changed, 20 insertions(+), 5 deletions(-) diff --git a/src/main/java/com/ruoyi/common/xss/XssFilter.java b/src/main/java/com/ruoyi/common/xss/XssFilter.java index 7e3435e4..50179423 100644 --- a/src/main/java/com/ruoyi/common/xss/XssFilter.java +++ b/src/main/java/com/ruoyi/common/xss/XssFilter.java @@ -14,6 +14,7 @@ import javax.servlet.ServletResponse; import javax.servlet.annotation.WebFilter; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; +import com.ruoyi.common.utils.StringUtils; /** * 防止XSS攻击的过滤器 @@ -23,24 +24,33 @@ import javax.servlet.http.HttpServletResponse; @WebFilter(filterName = "xssFilter", urlPatterns = "/system/*") public class XssFilter implements Filter { - /** * 排除链接 */ public List excludes = new ArrayList<>(); + /** + * xss过滤开关 + */ + public boolean xssEbabled = false; + @Override public void init(FilterConfig filterConfig) throws ServletException { - String temp = filterConfig.getInitParameter("excludes"); - if (temp != null) + String tempExcludes = filterConfig.getInitParameter("excludes"); + String tempXssEbabled = filterConfig.getInitParameter("xssEbabled"); + if (tempExcludes != null) { - String[] url = temp.split(","); + String[] url = tempExcludes.split(","); for (int i = 0; url != null && i < url.length; i++) { excludes.add(url[i]); } } + if (StringUtils.isNotEmpty(tempXssEbabled)) + { + xssEbabled = Boolean.valueOf(tempXssEbabled); + } } @Override @@ -64,6 +74,10 @@ public class XssFilter implements Filter { return false; } + if (!xssEbabled) + { + return true; + } String url = request.getServletPath(); for (String pattern : excludes) { diff --git a/src/main/java/com/ruoyi/framework/config/FilterConfig.java b/src/main/java/com/ruoyi/framework/config/FilterConfig.java index b63175eb..5ef85396 100644 --- a/src/main/java/com/ruoyi/framework/config/FilterConfig.java +++ b/src/main/java/com/ruoyi/framework/config/FilterConfig.java @@ -27,7 +27,8 @@ public class FilterConfig registration.setName("xssFilter"); registration.setOrder(Integer.MAX_VALUE); Map initParameters = Maps.newHashMap(); - initParameters.put("excludes", "/system/notice/*"); + initParameters.put("excludes", "/system/notice/*,/img/*,/css/*,/fonts/*,/js/*,/ajax/*,/ruoyi/*"); + initParameters.put("xssEbabled", "false"); registration.setInitParameters(initParameters); return registration; }