JSP使用過濾器防止SQL注入的簡單實(shí)現(xiàn)
什么是SQL注入攻擊?引用百度百科的解釋:
sql注入_百度百科:
所謂SQL注入,就是通過把SQL命令插入到Web表單提交或輸入域名或頁面請(qǐng)求的查詢字符串,最終達(dá)到欺騙服務(wù)器執(zhí)行惡意的SQL命令。具體來說,它是利用現(xiàn)有應(yīng)用程序,將(惡意)的SQL命令注入到后臺(tái)數(shù)據(jù)庫引擎執(zhí)行的能力,它可以通過在Web表單中輸入(惡意)SQL語句得到一個(gè)存在安全漏洞的網(wǎng)站上的數(shù)據(jù)庫,而不是按照設(shè)計(jì)者意圖去執(zhí)行SQL語句。[1] 比如先前的很多影視網(wǎng)站泄露VIP會(huì)員密碼大多就是通過WEB表單遞交查詢字符暴出的,這類表單特別容易受到SQL注入式攻擊.
SQL注入攻擊指的是通過構(gòu)建特殊的輸入作為參數(shù)傳入Web應(yīng)用程序,而這些輸入大都是SQL語法里的一些組合,通過執(zhí)行SQL語句進(jìn)而執(zhí)行攻擊者所要的操作,其主要原因是程序沒有細(xì)致地過濾用戶輸入的數(shù)據(jù),致使非法數(shù)據(jù)侵入系統(tǒng)。
filter功能:
它使用戶可以改變一個(gè) request和修改一個(gè)response. Filter 不是一個(gè)servlet,它不能產(chǎn)生一個(gè)response,它能夠
在一個(gè)request到達(dá)servlet之前預(yù)處理request,也可以在離開 servlet時(shí)處理response.
換種說法,filter其實(shí)是一個(gè)”servlet chaining”(servlet 鏈). 所以用戶發(fā)出的任何request都必然經(jīng)過filter處理,我們就在filter處理用戶request包含的敏感關(guān)鍵字,然后replace掉或是讓頁面轉(zhuǎn)到錯(cuò)誤頁來提示用戶,這樣就可以很好的防sql注入了。
具體實(shí)現(xiàn)代碼:
/YourProject/src/com/SqlFilter.java
package com; import java.io.IOException; import java.util.Enumeration; 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; import javax.servlet.http.HttpServletResponse; //過濾sql關(guān)鍵字的Filter public class SqlFilter implements Filter { public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest req = (HttpServletRequest) request; HttpServletResponse res = (HttpServletResponse) response; //獲得所有請(qǐng)求參數(shù)名 Enumeration params = req.getParameterNames(); String sql = ""; while (params.hasMoreElements()) { //得到參數(shù)名 String name = params.nextElement().toString(); //System.out.println("name===========================" + name + "--"); //得到參數(shù)對(duì)應(yīng)值 String[] value = req.getParameterValues(name); for (int i = 0; i < value.length; i++) { sql = sql + value[i]; } } System.out.println("被匹配字符串:"+sql); if (sqlValidate(sql)) { res.sendRedirect("error.jsp"); } else { chain.doFilter(req, res); } } //校驗(yàn) protected static boolean sqlValidate(String str) { str = str.toLowerCase();//統(tǒng)一轉(zhuǎn)為小寫 //String badStr = "and|exec"; String badStr = "'|and|exec|execute|insert|select|delete|update|count|drop|chr|mid|master|truncate|char|declare|sitename|net user|xp_cmdshell|or|like"; /*String badStr = "'|and|exec|execute|insert|create|drop|table|from|grant|use|group_concat|column_name|" + "information_schema.columns|table_schema|union|where|select|delete|update|order|by|count|*|" + "chr|mid|master|truncate|char|declare|or|;|-|--|+|,|like|//|/|%|#"; */ //過濾掉的sql關(guān)鍵字,可以手動(dòng)添加 String[] badStrs = badStr.split("\\|"); for (int i = 0; i < badStrs.length; i++) { if (str.indexOf(badStrs[i]) !=-1) { System.out.println("匹配到:"+badStrs[i]); return true; } } return false; } public void init(FilterConfig filterConfig) throws ServletException { //throw new UnsupportedOperationException("Not supported yet."); } public void destroy() { //throw new UnsupportedOperationException("Not supported yet."); } }
注意上面第50行 如果用“|”作為分隔的話,必須是如下寫法:String.split("\\|"),這樣才能正確的分隔開,不能用String.split("|");
/YourProject/WebContent/WEB-INF/web.xml(在web.xml中過濾器添加過濾器配置):
<!-- sql Filter --> <filter> <filter-name>SqlFilter</filter-name> <filter-class>com.SqlFilter</filter-class> </filter> <filter-mapping> <filter-name>SqlFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
/YourProject/WebContent/error.jsp(檢測到sql關(guān)鍵詞跳轉(zhuǎn)到的頁面):
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>error</title> </head> <body> <div align="center"> <br> <h4>非法輸入</h4> <p><input type="button" name="back" value="返回" onclick="javascript:history.go(-1);"/> </div> </body> </html>
將上面的過濾器加入到自己的項(xiàng)目中可以簡單地防止SQL注入,嚴(yán)格防止注入還需采取更有效的措施。
同理,我們也可以使用過濾器實(shí)現(xiàn)敏感詞的屏蔽功能,用法和防止SQL注入類似,自行探索!
我是分割線
-----------------------------------------
更多防范SQL注入的措施:
1.對(duì)輸入進(jìn)行嚴(yán)格的限制和過濾
2.對(duì)一些應(yīng)用如數(shù)據(jù)庫的連接進(jìn)行有效的IP限定
3.盡可能減少CGI程序中的系統(tǒng)調(diào)用
4.使用web掃描器預(yù)先掃描系統(tǒng)
5.下載SQL通用防注入系統(tǒng)的程序,在需要防范注入的頁面頭部用<!--# include file=”xxx.asp”-- >來防止別人進(jìn)行手動(dòng)注入測試 (針對(duì)asp網(wǎng)頁)
6.設(shè)置陷阱賬號(hào):設(shè)置兩個(gè)帳號(hào),一個(gè)是普通管理員帳號(hào),一個(gè)是防注入的帳號(hào)。將防注入的賬號(hào)設(shè)置的很象管理員,如 admin,以制造假象吸引軟件的檢測,而密碼是大于千字以上的中文字符,迫使軟件分析賬號(hào)的時(shí)候進(jìn)入全負(fù)荷狀態(tài)甚至資源耗盡而死機(jī)。
以上這篇JSP使用過濾器防止SQL注入的簡單實(shí)現(xiàn)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 通過過濾器(Filter)解決JSP的Post和Request中文亂碼問題
- JSP過濾器Filter配置過濾類型全部匯總
- JSP 開發(fā)中過濾器filter設(shè)置編碼格式的實(shí)現(xiàn)方法
- JSP使用Servlet過濾器進(jìn)行身份驗(yàn)證的方法
- JSP過濾器防止Xss漏洞的實(shí)現(xiàn)方法(分享)
- jsp實(shí)現(xiàn)登錄驗(yàn)證的過濾器
- jsp中過濾器選擇過濾器的寫法詳解
- 詳解JSP中使用過濾器進(jìn)行內(nèi)容編碼的解決辦法
- servlet+jsp實(shí)現(xiàn)過濾器 防止用戶未登錄訪問
- JSP使用過濾器防止Xss漏洞
- jsp filter 過濾器功能與簡單用法示例
相關(guān)文章
從textarea中獲取數(shù)據(jù)之后按原樣顯示實(shí)現(xiàn)代碼
從textarea中獲取數(shù)據(jù),按原樣顯示在某些特殊的情況下還是比較使實(shí)用的,下面為大家分享下實(shí)現(xiàn)代碼,感興趣的朋友可以參考下,希望對(duì)你有所幫助2013-04-04Servlet實(shí)現(xiàn)文件上傳的三種方法總結(jié)
這篇文章主要介紹了Servlet實(shí)現(xiàn)文件上傳的三種方法總結(jié)的相關(guān)資料,這里提供三種實(shí)例,幫助大家理解這部分內(nèi)容,需要的朋友可以參考下2017-08-08web前端超出兩行用省略號(hào)表示的實(shí)現(xiàn)方法
這篇文章主要介紹了web前端超出兩行用省略號(hào)表示的實(shí)現(xiàn)方法的相關(guān)資料,希望通過本文能幫助到大家,讓大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-10-10Java Web開發(fā)之圖形驗(yàn)證碼的生成與使用方法
這篇文章主要介紹了Java Web開發(fā)之圖形驗(yàn)證碼的生成與使用方法,較為詳細(xì)的分析了JSP驗(yàn)證碼的實(shí)現(xiàn)原理與生成技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-09-09JSP頁面的靜態(tài)包含和動(dòng)態(tài)包含使用方法
這篇文章主要介紹了JSP頁面的靜態(tài)包含和動(dòng)態(tài)包含使用方法,需要的朋友可以參考下2018-01-01