xss加入配置文件

pull/23/MERGE
RuoYi 2018-08-13 21:40:50 +08:00
parent e8eaeadbb0
commit f67d7179cd
7 changed files with 43 additions and 25 deletions

View File

@ -45,7 +45,7 @@ public interface ShiroConstants
/** /**
* *
*/ */
public static final String CURRENT_EBABLED = "captchaEbabled"; public static final String CURRENT_ENABLED = "captchaEnabled";
/** /**
* *

View File

@ -11,7 +11,6 @@ import javax.servlet.FilterConfig;
import javax.servlet.ServletException; import javax.servlet.ServletException;
import javax.servlet.ServletRequest; import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse; import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import com.ruoyi.common.utils.StringUtils; import com.ruoyi.common.utils.StringUtils;
@ -21,7 +20,6 @@ import com.ruoyi.common.utils.StringUtils;
* *
* @author ruoyi * @author ruoyi
*/ */
@WebFilter(filterName = "xssFilter", urlPatterns = "/system/*")
public class XssFilter implements Filter public class XssFilter implements Filter
{ {
/** /**
@ -32,14 +30,14 @@ public class XssFilter implements Filter
/** /**
* xss * xss
*/ */
public boolean xssEbabled = false; public boolean enabled = false;
@Override @Override
public void init(FilterConfig filterConfig) throws ServletException public void init(FilterConfig filterConfig) throws ServletException
{ {
String tempExcludes = filterConfig.getInitParameter("excludes"); String tempExcludes = filterConfig.getInitParameter("excludes");
String tempXssEbabled = filterConfig.getInitParameter("xssEbabled"); String tempEnabled = filterConfig.getInitParameter("enabled");
if (tempExcludes != null) if (StringUtils.isNotEmpty(tempExcludes))
{ {
String[] url = tempExcludes.split(","); String[] url = tempExcludes.split(",");
for (int i = 0; url != null && i < url.length; i++) for (int i = 0; url != null && i < url.length; i++)
@ -47,9 +45,9 @@ public class XssFilter implements Filter
excludes.add(url[i]); excludes.add(url[i]);
} }
} }
if (StringUtils.isNotEmpty(tempXssEbabled)) if (StringUtils.isNotEmpty(tempEnabled))
{ {
xssEbabled = Boolean.valueOf(tempXssEbabled); enabled = Boolean.valueOf(tempEnabled);
} }
} }
@ -70,14 +68,14 @@ public class XssFilter implements Filter
private boolean handleExcludeURL(HttpServletRequest request, HttpServletResponse response) private boolean handleExcludeURL(HttpServletRequest request, HttpServletResponse response)
{ {
if (!enabled)
{
return true;
}
if (excludes == null || excludes.isEmpty()) if (excludes == null || excludes.isEmpty())
{ {
return false; return false;
} }
if (!xssEbabled)
{
return true;
}
String url = request.getServletPath(); String url = request.getServletPath();
for (String pattern : excludes) for (String pattern : excludes)
{ {

View File

@ -2,10 +2,12 @@ package com.ruoyi.framework.config;
import java.util.Map; import java.util.Map;
import javax.servlet.DispatcherType; import javax.servlet.DispatcherType;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.servlet.FilterRegistrationBean; import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Configuration;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.common.xss.XssFilter; import com.ruoyi.common.xss.XssFilter;
/** /**
@ -16,6 +18,15 @@ import com.ruoyi.common.xss.XssFilter;
@Configuration @Configuration
public class FilterConfig public class FilterConfig
{ {
@Value("${xss.enabled}")
private String enabled;
@Value("${xss.excludes}")
private String excludes;
@Value("${xss.urlPatterns}")
private String urlPatterns;
@SuppressWarnings({ "rawtypes", "unchecked" }) @SuppressWarnings({ "rawtypes", "unchecked" })
@Bean @Bean
public FilterRegistrationBean xssFilterRegistration() public FilterRegistrationBean xssFilterRegistration()
@ -23,12 +34,12 @@ public class FilterConfig
FilterRegistrationBean registration = new FilterRegistrationBean(); FilterRegistrationBean registration = new FilterRegistrationBean();
registration.setDispatcherTypes(DispatcherType.REQUEST); registration.setDispatcherTypes(DispatcherType.REQUEST);
registration.setFilter(new XssFilter()); registration.setFilter(new XssFilter());
registration.addUrlPatterns("/*"); registration.addUrlPatterns(StringUtils.split(urlPatterns, ","));
registration.setName("xssFilter"); registration.setName("xssFilter");
registration.setOrder(Integer.MAX_VALUE); registration.setOrder(Integer.MAX_VALUE);
Map<String, String> initParameters = Maps.newHashMap(); Map<String, String> initParameters = Maps.newHashMap();
initParameters.put("excludes", "/system/notice/*,/img/*,/css/*,/fonts/*,/js/*,/ajax/*,/ruoyi/*"); initParameters.put("excludes", excludes);
initParameters.put("xssEbabled", "false"); initParameters.put("enabled", enabled);
registration.setInitParameters(initParameters); registration.setInitParameters(initParameters);
return registration; return registration;
} }

View File

@ -46,8 +46,8 @@ public class ShiroConfig
private int validationInterval; private int validationInterval;
// 验证码开关 // 验证码开关
@Value("${shiro.user.captchaEbabled}") @Value("${shiro.user.captchaEnabled}")
private boolean captchaEbabled; private boolean captchaEnabled;
// 验证码类型 // 验证码类型
@Value("${shiro.user.captchaType}") @Value("${shiro.user.captchaType}")
@ -297,7 +297,7 @@ public class ShiroConfig
public CaptchaValidateFilter captchaValidateFilter() public CaptchaValidateFilter captchaValidateFilter()
{ {
CaptchaValidateFilter captchaValidateFilter = new CaptchaValidateFilter(); CaptchaValidateFilter captchaValidateFilter = new CaptchaValidateFilter();
captchaValidateFilter.setCaptchaEbabled(captchaEbabled); captchaValidateFilter.setCaptchaEnabled(captchaEnabled);
captchaValidateFilter.setCaptchaType(captchaType); captchaValidateFilter.setCaptchaType(captchaType);
return captchaValidateFilter; return captchaValidateFilter;
} }

View File

@ -20,16 +20,16 @@ public class CaptchaValidateFilter extends AccessControlFilter
/** /**
* *
*/ */
private boolean captchaEbabled = true; private boolean captchaEnabled = true;
/** /**
* *
*/ */
private String captchaType = "math"; private String captchaType = "math";
public void setCaptchaEbabled(boolean captchaEbabled) public void setCaptchaEnabled(boolean captchaEnabled)
{ {
this.captchaEbabled = captchaEbabled; this.captchaEnabled = captchaEnabled;
} }
public void setCaptchaType(String captchaType) public void setCaptchaType(String captchaType)
@ -40,7 +40,7 @@ public class CaptchaValidateFilter extends AccessControlFilter
@Override @Override
public boolean onPreHandle(ServletRequest request, ServletResponse response, Object mappedValue) throws Exception public boolean onPreHandle(ServletRequest request, ServletResponse response, Object mappedValue) throws Exception
{ {
request.setAttribute(ShiroConstants.CURRENT_EBABLED, captchaEbabled); request.setAttribute(ShiroConstants.CURRENT_ENABLED, captchaEnabled);
request.setAttribute(ShiroConstants.CURRENT_TYPE, captchaType); request.setAttribute(ShiroConstants.CURRENT_TYPE, captchaType);
return super.onPreHandle(request, response, mappedValue); return super.onPreHandle(request, response, mappedValue);
} }
@ -51,7 +51,7 @@ public class CaptchaValidateFilter extends AccessControlFilter
{ {
HttpServletRequest httpServletRequest = (HttpServletRequest) request; HttpServletRequest httpServletRequest = (HttpServletRequest) request;
// 验证码禁用 或不是表单提交 允许访问 // 验证码禁用 或不是表单提交 允许访问
if (captchaEbabled == false || !"post".equals(httpServletRequest.getMethod().toLowerCase())) if (captchaEnabled == false || !"post".equals(httpServletRequest.getMethod().toLowerCase()))
{ {
return true; return true;
} }

View File

@ -40,6 +40,7 @@ spring:
thymeleaf: thymeleaf:
mode: HTML mode: HTML
encoding: utf-8 encoding: utf-8
# 禁用缓存
cache: false cache: false
messages: messages:
#国际化资源文件路径 #国际化资源文件路径
@ -82,7 +83,7 @@ shiro:
# 首页地址 # 首页地址
indexUrl: /index indexUrl: /index
# 验证码开关 # 验证码开关
captchaEbabled: true captchaEnabled: true
# 验证码类型 math 数组计算 char 字符 # 验证码类型 math 数组计算 char 字符
captchaType: math captchaType: math
cookie: cookie:
@ -101,6 +102,14 @@ shiro:
dbSyncPeriod: 1 dbSyncPeriod: 1
# 相隔多久检查一次session的有效性默认就是10分钟 # 相隔多久检查一次session的有效性默认就是10分钟
validationInterval: 10 validationInterval: 10
# 防止XSS攻击
xss:
# 过滤开关
enabled: true
# 排除链接(多个用逗号分隔)
excludes: /system/notice/*
# 匹配链接
urlPatterns: /system/*,/monitor/*,/tool/*
# 代码生成 # 代码生成
gen: gen:
# 作者 # 作者

View File

@ -50,7 +50,7 @@
<p class="m-t-md">你若不离不弃,我必生死相依</p> <p class="m-t-md">你若不离不弃,我必生死相依</p>
<input type="text" name="username" class="form-control uname" placeholder="用户名" value="admin" /> <input type="text" name="username" class="form-control uname" placeholder="用户名" value="admin" />
<input type="password" name="password" class="form-control pword m-b" placeholder="密码" value="admin123" /> <input type="password" name="password" class="form-control pword m-b" placeholder="密码" value="admin123" />
<div class="row" th:if="${captchaEbabled==true}"> <div class="row" th:if="${captchaEnabled==true}">
<div class="col-xs-6"> <div class="col-xs-6">
<input type="text" name="validateCode" class="form-control code" placeholder="验证码" maxlength="5"> <input type="text" name="validateCode" class="form-control code" placeholder="验证码" maxlength="5">
</div> </div>