java 过滤xss脚本_Java Web应用程序的反跨站点脚本(XSS)过滤器
生活随笔
收集整理的這篇文章主要介紹了
java 过滤xss脚本_Java Web应用程序的反跨站点脚本(XSS)过滤器
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
java 過濾xss腳本
這是為Java Web應用程序編寫的一個好簡單的反跨站點腳本(XSS)過濾器。 它的基本作用是從請求參數中刪除所有可疑字符串,然后將其返回給應用程序。 這是我以前關于該主題的帖子的改進。 您應該將其配置為鏈(web.xml)中的第一個過濾器,通常最好讓它捕獲對您站點的所有請求。 實際的實現包括兩個類,實際的過濾器非常簡單,它將HTTP請求對象包裝在一個專門的HttpServletRequestWrapper中,它將執行我們的過濾。 public class XSSFilter implements Filter {@Overridepublic void init(FilterConfig filterConfig) throws ServletException {}@Overridepublic void destroy() {}@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {chain.doFilter(new XSSRequestWrapper((HttpServletRequest) request), response);}}包裝程序將覆蓋getParameterValues(),getParameter()和getHeader()方法,以在將所需字段返回給調用方之前執行過濾。 實際的XSS檢查和剝離是在stripXSS()私有方法中執行的。
import java.util.regex.Pattern; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequestWrapper;public class XSSRequestWrapper extends HttpServletRequestWrapper {public XSSRequestWrapper(HttpServletRequest servletRequest) {super(servletRequest);}@Overridepublic String[] getParameterValues(String parameter) {String[] values = super.getParameterValues(parameter);if (values == null) {return null;}int count = values.length;String[] encodedValues = new String[count];for (int i = 0; i < count; i++) {encodedValues[i] = stripXSS(values[i]);}return encodedValues;}@Overridepublic String getParameter(String parameter) {String value = super.getParameter(parameter);return stripXSS(value);}@Overridepublic String getHeader(String name) {String value = super.getHeader(name);return stripXSS(value);}private String stripXSS(String value) {if (value != null) {// NOTE: It's highly recommended to use the ESAPI library and uncomment the following line to// avoid encoded attacks.// value = ESAPI.encoder().canonicalize(value);// Avoid null charactersvalue = value.replaceAll("", "");// Avoid anything between script tagsPattern scriptPattern = Pattern.compile("<script>(.*?)</script>", Pattern.CASE_INSENSITIVE);value = scriptPattern.matcher(value).replaceAll("");// Avoid anything in a src='...' type of expressionscriptPattern = Pattern.compile("src[\r\n]*=[\r\n]*\\\'(.*?)\\\'", Pattern.CASE_INSENSITIVE | Pattern.MULTILINE | Pattern.DOTALL);value = scriptPattern.matcher(value).replaceAll("");scriptPattern = Pattern.compile("src[\r\n]*=[\r\n]*\\\"(.*?)\\\"", Pattern.CASE_INSENSITIVE | Pattern.MULTILINE | Pattern.DOTALL);value = scriptPattern.matcher(value).replaceAll("");// Remove any lonesome </script> tagscriptPattern = Pattern.compile("</script>", Pattern.CASE_INSENSITIVE);value = scriptPattern.matcher(value).replaceAll("");// Remove any lonesome <script ...> tagscriptPattern = Pattern.compile("<script(.*?)>", Pattern.CASE_INSENSITIVE | Pattern.MULTILINE | Pattern.DOTALL);value = scriptPattern.matcher(value).replaceAll("");// Avoid eval(...) expressionsscriptPattern = Pattern.compile("eval\\((.*?)\\)", Pattern.CASE_INSENSITIVE | Pattern.MULTILINE | Pattern.DOTALL);value = scriptPattern.matcher(value).replaceAll("");// Avoid expression(...) expressionsscriptPattern = Pattern.compile("expression\\((.*?)\\)", Pattern.CASE_INSENSITIVE | Pattern.MULTILINE | Pattern.DOTALL);value = scriptPattern.matcher(value).replaceAll("");// Avoid javascript:... expressionsscriptPattern = Pattern.compile("javascript:", Pattern.CASE_INSENSITIVE);value = scriptPattern.matcher(value).replaceAll("");// Avoid vbscript:... expressionsscriptPattern = Pattern.compile("vbscript:", Pattern.CASE_INSENSITIVE);value = scriptPattern.matcher(value).replaceAll("");// Avoid onload= expressionsscriptPattern = Pattern.compile("onload(.*?)=", Pattern.CASE_INSENSITIVE | Pattern.MULTILINE | Pattern.DOTALL);value = scriptPattern.matcher(value).replaceAll("");}return value;} }請注意有關ESAPI庫的注釋,我強烈建議您將其檢出并嘗試將其包含在項目中。
如果您想深入了解該主題,建議您查看有關XSS和RSnake的XSS(跨站點腳本)備忘單的 OWASP頁面 。
參考: Ricardo Zuasti博客博客中的JCG合作伙伴 Ricardo Zuasti提供了針對Java Web應用程序的更強大的反跨站點腳本(XSS)過濾器 。
翻譯自: https://www.javacodegeeks.com/2012/07/anti-cross-site-scripting-xss-filter.html
java 過濾xss腳本
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的java 过滤xss脚本_Java Web应用程序的反跨站点脚本(XSS)过滤器的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 备案是怎么回事(备案怎么回事)
- 下一篇: 将Java 8流解析为SQL