成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

JSP使用過濾器防止Xss漏洞

瀏覽:453日期:2022-06-07 14:50:39

在用java進行web業務開發的時候,對于頁面上接收到的參數,除了極少數是步可預知的內容外,大量的參數名和參數值都是不會出現觸發Xss漏洞的字符。而通常為了避免Xss漏洞,都是開發人員各自在頁面輸出和數據入庫等地方加上各種各樣的encode方法來避免Xss問題。而由于開發人員的水平不一,加上在編寫代碼的過程中安全意識的差異,可能會粗心漏掉對用戶輸入內容進行encode處理。針對這種大量參數是不可能出現引起Xss和SQL注入漏洞的業務場景下,因此可以使用一個適用大多數業務場景的通用處理方法,犧牲少量用戶體驗,來避免Xss漏洞和SQL注入。

那就是利用Servlet的過濾器機制,編寫定制的XssFilter,將request請求代理,覆蓋getParameter和getHeader方法將參數名和參數值里的指定半角字符,強制替換成全角字符。使得在業務層的處理時不用擔心會有異常輸入內容。

XssFilter.java

package filter;
 
import java.io.IOException;
 
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
 
public class XssFilter implements Filter {
 
 public void init(FilterConfig config) throws ServletException {
 }
 
 public void doFilter(ServletRequest request, ServletResponse response,
 FilterChain chain) throws IOException, ServletException 
 {
 XssHttpServletRequestWrapper xssRequest = new XssHttpServletRequestWrapper(
 (HttpServletRequest) request);
 chain.doFilter(xssRequest, response);
}
 
 public void destroy() {
 }
}

XssHttpServletRequestWrapper.java

package filter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
 
public class XssHttpServletRequestWrapper extends HttpServletRequestWrapper {
 HttpServletRequest orgRequest = null;
 
 public XssHttpServletRequestWrapper(HttpServletRequest request) {
 super(request);
 orgRequest = request;
 }
 
 /**
 * 覆蓋getParameter方法,將參數名和參數值都做xss過濾。<br/>
 * 如果需要獲得原始的值,則通過super.getParameterValues(name)來獲取<br/>
 * getParameterNames,getParameterValues和getParameterMap也可能需要覆蓋
 */
 @Override
 public String getParameter(String name) {
 String value = super.getParameter(xssEncode(name));
 if (value != null) {
 value = xssEncode(value);
 }
 return value;
}
 
/**
 * 覆蓋getHeader方法,將參數名和參數值都做xss過濾。<br/>
 * 如果需要獲得原始的值,則通過super.getHeaders(name)來獲取<br/>
 * getHeaderNames 也可能需要覆蓋
*/
 @Override
 public String getHeader(String name) {
 
 String value = super.getHeader(xssEncode(name));
 if (value != null) {
 value = xssEncode(value);
 }
 return value;
}
 
/**
 * 將容易引起xss漏洞的半角字符直接替換成全角字符
 *
 * @param s
 * @return
*/
private static String xssEncode(String s) {
if (s == null || s.isEmpty()) {
return s;
}
 StringBuilder sb = new StringBuilder(s.length() + 16);
 for (int i = 0; i < s.length(); i++) {
 char c = s.charAt(i);
 switch (c) {
 case ">":
 sb.append(">");//全角大于號
 break;
 case "<":
 sb.append("<");//全角小于號
 break;
 case "\"":
 sb.append("‘");//全角單引號
 break;
 case "\"":
 sb.append("“");//全角雙引號
 break;
 case "&":
 sb.append("&");//全角
 break;
 case "\\":
 sb.append("\");//全角斜線
 break;
 case "#":
 sb.append("#");//全角井號
 break;
 default:
 sb.append(c);
 break;
 }
}
 return sb.toString();
}
 
/**
* 獲取最原始的request
*
* @return
*/
public HttpServletRequest getOrgRequest() {
return orgRequest;
}
/**
* 獲取最原始的request的靜態方法
*
* @return
*/
 public static HttpServletRequest getOrgRequest(HttpServletRequest req) {
 if(req instanceof XssHttpServletRequestWrapper){
 return ((XssHttpServletRequestWrapper)req).getOrgRequest();
}
 
return req;
}
} 

在web.xml中添加

<filter>
<filter-name>xssFilter</filter-name>
 <filter-class>filter.XssFilter</filter-class>
 </filter>
 <filter-mapping>
 <filter-name>xssFilter</filter-name>
 <url-pattern>/*</url-pattern>
</filter-mapping>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。

標簽: JSP
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产亚洲精品中文字幕| 中日韩男男gay无套| 欧美精品国产一区| 日韩欧美国产麻豆| 精东粉嫩av免费一区二区三区| 日本精品一级二级| 午夜欧美大尺度福利影院在线看| 一区二区三区福利| 亚洲视频一区二区在线| 亚洲亚洲精品三区日韩精品在线视频| 国产欧美精品一区二区三区四区| 91小视频在线观看| 国产色一区二区| 欧美二区在线| 日韩精品自拍偷拍| 成人的网站免费观看| 欧美一级国产精品| 成人一级片在线观看| 精品av久久707| 91浏览器打开| 国产欧美一区二区在线| 欧美日韩国产免费观看 | 白白色 亚洲乱淫| 日韩免费一区二区三区在线播放| 国产白丝网站精品污在线入口| 日韩欧美中文字幕制服| 99久免费精品视频在线观看| 欧美mv和日韩mv国产网站| 99这里只有久久精品视频| 久久精品一区二区| 狠狠入ady亚洲精品| 亚洲美女区一区| 亚洲一区三区电影在线观看| 无吗不卡中文字幕| 欧美视频一区在线观看| 国产成人精品一区二区三区网站观看| 精品国产一区二区三区不卡| 欧美 日韩 国产 一区| 自拍偷在线精品自拍偷无码专区| 亚洲欧美视频一区二区三区| 日韩成人精品在线| 欧美性色aⅴ视频一区日韩精品| 寂寞少妇一区二区三区| 欧美大片拔萝卜| 91社区在线播放| 中文字幕在线播放不卡一区| 国产欧美不卡| 青草国产精品久久久久久| 欧美一区日本一区韩国一区| 99九九99九九九视频精品| 国产精品久久久久精k8| 中文字幕精品综合| 米奇777在线欧美播放| 国产一区二区看久久| 欧美韩国一区二区| 亚洲一区综合| 国内不卡的二区三区中文字幕 | 亚洲国产成人tv| 欧美日韩久久一区二区| 97aⅴ精品视频一二三区| 亚洲人123区| 在线精品国精品国产尤物884a| 成人性生交大片免费看视频在线 | 盗摄精品av一区二区三区| 精品对白一区国产伦| 日韩亚洲视频在线| 免费高清不卡av| 久久久久久综合| 亚洲欧美日韩在线综合| 国产精品夜夜嗨| 国产精品久久久久aaaa樱花 | 亚洲一区二区免费看| 美日韩一区二区| 久久久www成人免费毛片麻豆| 亚洲精品一级| 国模无码大尺度一区二区三区| 中文字幕国产一区| 欧美在线视频你懂得| 91老司机福利 在线| 天堂蜜桃一区二区三区 | 亚洲黄色小说网站| 欧美精品国产精品| 亚洲午夜av| 另类小说图片综合网| 国产日韩视频一区二区三区| 色婷婷综合在线| 91视频免费看| 天天色天天操综合| 精品黑人一区二区三区久久 | 久久精品官网| 成人av网在线| 日精品一区二区| 国产日韩欧美精品综合| 欧美自拍偷拍午夜视频| 亚洲视频福利| 亚洲一区电影777| 欧美va亚洲va在线观看蝴蝶网| 国产精品一区视频网站| www.成人在线| 毛片av中文字幕一区二区| 国产精品美女久久久久久久久| 在线观看视频欧美| 欧美日韩三级电影在线| 精品一区精品二区高清| 国产亚洲成aⅴ人片在线观看| 久久精品卡一| 欧美人与禽猛交乱配| 激情综合亚洲精品| 亚洲一区欧美一区| 久久欧美中文字幕| 欧美性xxxxxxxx| av成人毛片| 99久久精品国产网站| 另类中文字幕网| 亚洲影院在线观看| 欧美经典三级视频一区二区三区| 欧美亚洲丝袜传媒另类| 99精品国产在热久久| 91蝌蚪porny| 国产美女在线精品| 日韩在线一区二区三区| 亚洲私人影院在线观看| 久久久精品中文字幕麻豆发布| 欧美日韩成人综合在线一区二区| 一区二区av| 欧美另类视频| 丁香天五香天堂综合| 人妖欧美一区二区| 伊人婷婷欧美激情| 欧美经典一区二区三区| 日韩免费视频一区二区| 欧洲一区二区av| 久久不射网站| 一区二区三区久久网| 亚洲午夜精品久久久久久app| caoporn国产一区二区| 国产精品影音先锋| 蜜桃精品在线观看| 亚洲妇熟xx妇色黄| 一区二区在线看| 国产精品美女久久久久久久久 | 99久久久国产精品| 国产精品中文字幕欧美| 免费三级欧美电影| 午夜精品久久久久影视| 一区二区三区四区亚洲| 国产精品剧情在线亚洲| 久久久久99精品一区| 精品久久久久久亚洲综合网| 91超碰这里只有精品国产| 欧美这里有精品| 在线观看亚洲a| 在线国产电影不卡| 日本道在线观看一区二区| 久久久999| 国产精品一区视频| 一区二区视频欧美| 欧美久久久久久| 欧美日韩免费高清| 欧美成人精品| 女人香蕉久久**毛片精品| 91免费版pro下载短视频| 国产69精品久久久久毛片| 香蕉影视欧美成人| 亚洲国产一区二区在线播放| 一区二区三区在线免费观看| 亚洲精品你懂的| 亚洲激情中文1区| 一个色综合网站| 一区二区高清视频在线观看| 亚洲欧美区自拍先锋| 一区二区三区在线视频免费| 亚洲综合在线免费观看| 亚洲五码中文字幕| 日欧美一区二区| 毛片基地黄久久久久久天堂| 久久99精品久久只有精品| 国产综合色视频| 国产成人无遮挡在线视频| 丁香啪啪综合成人亚洲小说 | av不卡一区二区三区| www.视频一区| 午夜日韩激情| 欧美特级限制片免费在线观看| 在线观看亚洲精品视频| 欧美性色黄大片手机版| 欧美日韩极品在线观看一区| 在线播放视频一区| 欧美一区二区三区视频免费| 精品99999| 国产精品午夜春色av| 成人欧美一区二区三区黑人麻豆| 亚洲成人直播| 亚洲一区中文| 在线亚洲高清视频| 欧美久久久久中文字幕| 日韩视频免费观看高清完整版| 韩国成人在线视频| 国产呦精品一区二区三区网站| 成人午夜电影网站|