Spring Boot Filter不过滤指定资源,绕过不需要过滤的资源

不凡 后台 9.7K+

用富文本编辑器存到后台的是html,系统中有一个xxs防注入功能,所以到后台富文本的值别过滤变成纯文本了。如下图

前台获取到的是正常的HTML数据

Spring Boot Filter不过滤指定资源,绕过不需要过滤的资源-第1张图片-爱制作博客

到后台就被过滤成纯文本的汉字了

Spring Boot Filter不过滤指定资源,绕过不需要过滤的资源-第2张图片-爱制作博客

这样展现的时候之前输入的东西样式全乱了

Spring Boot Filter不过滤指定资源,绕过不需要过滤的资源-第3张图片-爱制作博客

首先找到项目Filter配置 的类,找到过滤HTML的方法,加上不需要进行过滤的请求地址

Spring Boot Filter不过滤指定资源,绕过不需要过滤的资源-第4张图片-爱制作博客

然后在对应的类中进行判断过滤

Spring Boot Filter不过滤指定资源,绕过不需要过滤的资源-第5张图片-爱制作博客

这样就OK了。

完整代码:

import io.base.common.xss.XssFilter;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.filter.DelegatingFilterProxy;

import javax.servlet.DispatcherType;

/**
 * Filter配置
 *
 * @author 爱制作
 */
@Configuration
public class FilterConfig {


    @Bean
    public FilterRegistrationBean xssFilterRegistration() {
        FilterRegistrationBean registration = new FilterRegistrationBean();
        registration.setDispatcherTypes(DispatcherType.REQUEST);
        registration.setFilter(new XssFilter());
        registration.addUrlPatterns("/*");
        registration.addInitParameter("notice","*/sysnotice/*");
        registration.setName("xssFilter");
        registration.setOrder(Integer.MAX_VALUE);
        return registration;
    }
}
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;

/**
 * XSS过滤
 * @author 爱制作
 * @email ibufan@outlook.com
 */
public class XssFilter implements Filter {

   private String[] excludedUris;

   @Override
   public void init(FilterConfig config) throws ServletException {
      excludedUris = config.getInitParameter("notice").split(",");
   }

   @Override
   public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
            throws IOException, ServletException {
      XssHttpServletRequestWrapper xssRequest = new XssHttpServletRequestWrapper(
            (HttpServletRequest) request);
      String url = xssRequest.getServletPath();
      if (isExcludedUri(url)){
         chain.doFilter(request, response);
      }else {
         chain.doFilter(xssRequest, response);
      }
   }

   @Override
   public void destroy() {
   }

   private boolean isExcludedUri(String uri) {
      if (excludedUris == null || excludedUris.length <= 0) {
         return false;
      }
      for (String ex : excludedUris) {
         uri = uri.trim();
         ex = ex.trim();
         if (uri.toLowerCase().matches(ex.toLowerCase().replace("*",".*")))
            return true;
      }
      return false;
   }
}


标签: SpringBoot Filter

发布评论 1条评论)

  • Refresh code

评论列表

2019-06-24 09:28:39

6666