日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

JSP使用過濾器防止Xss漏洞

瀏覽:529日期: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
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美综合二区| 午夜欧美理论片| 91久久久精品国产| 国产日韩电影| 国产一区不卡| 精品视频自拍| 精品精品久久| 精品一区二区三区视频在线播放| 亚洲在线国产日韩欧美| 成年男女免费视频网站不卡| 欧美激情视频一区二区三区免费| 日韩精品五月天| 亚欧洲精品视频在线观看| 亚洲综合另类| 少妇精品久久久一区二区| 日本 国产 欧美色综合| 亚洲精品看片| 欧美日韩黄网站| 国产精品任我爽爆在线播放 | 亚洲在线一区| 婷婷精品视频| 亚洲主播在线| 久久国产人妖系列| 精品日产乱码久久久久久仙踪林| 精品亚洲a∨| 久久精品中文| 亚洲精品伊人| 精品精品99| 欧美精选一区二区三区| 综合亚洲视频| 91亚洲人成网污www| 亚洲一区国产一区| 国产精品亚洲产品| 欧美1区免费| 欧美日韩精品一区二区三区视频 | 国产精品成久久久久| 1024精品一区二区三区| 一区二区电影| 国产aa精品| 亚洲理论在线| 免费一级欧美在线观看视频 | 高清av一区| 亚洲人成亚洲精品| 蜜桃av.网站在线观看| 免播放器亚洲一区| 精品视频一二| 亚洲精品三级| 欧美在线资源| 97精品国产福利一区二区三区| 丝袜美腿亚洲色图| 国产中文欧美日韩在线| 婷婷亚洲精品| 韩国久久久久久| 国产欧美88| 免费黄网站欧美| 久久精品卡一| 国产高潮在线| 国产精品羞羞答答在线观看| 亚洲在线免费| 日韩一级不卡| 午夜欧美巨大性欧美巨大| 国产精品va| 国产欧美日韩视频在线| 亚洲精品高潮| 男人天堂欧美日韩| 性色一区二区| 蜜臀av一区二区三区| 日本精品不卡| 欧美日韩在线观看首页| 精品三级在线| 麻豆中文一区二区| 国产精品1luya在线播放| 日本不卡视频在线观看| 蜜桃av一区二区在线观看| 欧美日韩国产亚洲一区| 91精品亚洲| 欧美va亚洲va日韩∨a综合色| 在线手机中文字幕| 久久精品网址| 久久99久久久精品欧美| 伊人久久一区| 国产精品99一区二区| 精品视频自拍| | 亚洲精品在线国产| 国产精品theporn| 毛片在线网站| 亚洲女同一区| 日本少妇精品亚洲第一区| 欧美精品三级在线| 麻豆久久久久久久| 日韩精品一区二区三区免费观影| 欧美日韩中文一区二区| 亚洲欧美日韩视频二区| 日韩精品午夜视频| 国产在线观看www| 婷婷精品视频| 91精品国产自产观看在线 | 97久久亚洲| 91亚洲国产高清| 久久国产高清| 成人日韩av| 精品一区亚洲| 国产欧美亚洲一区| 激情婷婷综合| 欧美a一区二区| 99在线观看免费视频精品观看| 日韩中文一区二区| 欧美三级精品| 国产精品欧美大片| 激情综合网站| 中文字幕在线看片| 91伊人久久| 国产精品日韩久久久| 国产精品蜜芽在线观看| 日韩av网站在线观看| 免费欧美一区| 亚洲香蕉网站| 亚洲午夜黄色| 欧美不卡在线| 亚洲精品成人| 美女国产一区| 亚洲精品1区2区| 日韩视频一区| 首页国产欧美日韩丝袜| 午夜欧美理论片| 亚洲女人av| 在线观看视频免费一区二区三区| 99在线|亚洲一区二区| 鲁大师成人一区二区三区| 在线视频日韩| 国产亚洲一级| 久久久成人网| 免费看av不卡| 四虎精品一区二区免费| 国产一区观看| 日韩成人亚洲| 精品中文在线| 国产精品中文字幕制服诱惑| 丝袜亚洲另类欧美| 视频一区中文| 婷婷综合社区| 日韩精选在线| 日韩精品三区四区| 少妇高潮一区二区三区99| 六月丁香综合| 亚洲精品一级二级三级| 国产精品毛片一区二区在线看| 亚洲一区日韩在线| 日韩精品久久久久久| 最新国产拍偷乱拍精品| 成人午夜亚洲| 香蕉成人久久| 在线亚洲欧美| 亚洲香蕉久久| 国产乱子精品一区二区在线观看 | 99精品国产一区二区三区| 麻豆视频在线观看免费网站黄 | 蜜桃视频一区二区| 日韩一区二区三免费高清在线观看 | 高清av不卡| 亚洲精品乱码| 国产精品天堂蜜av在线播放| 国产激情一区| 精品免费在线| a国产在线视频| 视频一区中文字幕| 日韩毛片一区| 日韩成人a**站| 亚洲一区国产一区| 麻豆精品久久| 精品在线91| 欧美激情久久久久久久久久久| 国产盗摄——sm在线视频| 精品91久久久久| 电影亚洲精品噜噜在线观看| 免费在线观看不卡| 麻豆91精品91久久久的内涵| 亚洲电影在线| 欧美精品日日操| 亚洲区国产区| 国产麻豆一区| 国产婷婷精品| 国产免费播放一区二区| 亚洲精品国产精品粉嫩| 狠狠久久伊人| 日本亚洲欧洲无免费码在线| av资源新版天堂在线| 国产成人久久精品麻豆二区 | 亚洲一区欧美激情| 成人在线视频中文字幕| 综合激情网...| 久久精品色播| 国产午夜精品一区在线观看| 1024精品久久久久久久久| 中文字幕亚洲影视| 欧美一级精品| 1000部精品久久久久久久久| 国产不卡精品| 精品国产乱码久久久久久樱花|