JSP使用過濾器防止SQL注入

什麼是SQL注入攻擊?引用百度百科的解釋:

sql注入_百度百科

所謂SQL注入,就是經過把SQL命令插入到Web表單提交或輸入域名或頁面請求的查詢字符串,最終達到欺騙服務器執行惡意的SQL命令。具體來講,它是利用現有應用程序,將(惡意)的SQL命令注入到後臺數據庫引擎執行的能力,它能夠經過在Web表單中輸入(惡意)SQL語句獲得一個存在安全漏洞的網站上的數據庫,而不是按照設計者意圖去執行SQL語句。[1]  好比先前的不少影視網站泄露VIP會員密碼大多就是經過WEB表單遞交查詢字符暴出的,這類表單特別容易受到SQL注入式攻擊javascript

SQL注入攻擊指的是經過構建特殊的輸入做爲參數傳入Web應用程序,而這些輸入大都是SQL語法裏的一些組合,經過執行SQL語句進而執行攻擊者所要的操做,其主要緣由是程序沒有細緻地過濾用戶輸入的數據,導致非法數據侵入系統。html

filter功能:

它使用戶能夠改變一個 request和修改一個response. Filter 不是一個servlet,它不能產生一個response,它可以java

在一個request到達servlet以前預處理request,也能夠在離開 servlet時處理response.web

換種說法,filter實際上是一個」servlet chaining」(servlet 鏈). 因此用戶發出的任何request都必然通過filter處理,咱們就在filter處理用戶request包含的敏感關鍵字,而後replace掉或是讓頁面轉到錯誤頁來提示用戶,這樣就能夠很好的防sql注入了。sql

具體實現代碼:

/YourProject/src/com/SqlFilter.javashell

 1 package com;
 2 import java.io.IOException;  
 3 import java.util.Enumeration;  
 4 import javax.servlet.Filter;  
 5 import javax.servlet.FilterChain;  
 6 import javax.servlet.FilterConfig;  
 7 import javax.servlet.ServletException;  
 8 import javax.servlet.ServletRequest;  
 9 import javax.servlet.ServletResponse;  
10 import javax.servlet.http.HttpServletRequest;  
11 import javax.servlet.http.HttpServletResponse;  
12   
13 //過濾sql關鍵字的Filter 
14 public class SqlFilter implements Filter {  
15   
16     public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {  
17   
18         HttpServletRequest req = (HttpServletRequest) request;  
19         HttpServletResponse res = (HttpServletResponse) response;  
20         //得到全部請求參數名  
21         Enumeration params = req.getParameterNames();  
22   
23         String sql = "";  
24         while (params.hasMoreElements()) {  
25             //獲得參數名  
26             String name = params.nextElement().toString();  
27             //System.out.println("name===========================" + name + "--");  
28             //獲得參數對應值  
29             String[] value = req.getParameterValues(name);  
30             for (int i = 0; i < value.length; i++) {  
31                 sql = sql + value[i];  
32             }  
33         }  
34         System.out.println("被匹配字符串:"+sql);  
35         if (sqlValidate(sql)) {  
36             res.sendRedirect("error.jsp");   
37         } else {  
38             chain.doFilter(req, res);  
39         }  
40     }  
41   
42     //校驗
43     protected static boolean sqlValidate(String str) {  
44         str = str.toLowerCase();//統一轉爲小寫
45         //String badStr = "and|exec";
46         String badStr = "'|and|exec|execute|insert|select|delete|update|count|drop|chr|mid|master|truncate|char|declare|sitename|net user|xp_cmdshell|or|like";  
47         /*String badStr = "'|and|exec|execute|insert|create|drop|table|from|grant|use|group_concat|column_name|" +  
48                 "information_schema.columns|table_schema|union|where|select|delete|update|order|by|count|*|" +  
49                 "chr|mid|master|truncate|char|declare|or|;|-|--|+|,|like|//|/|%|#";    */    //過濾掉的sql關鍵字,能夠手動添加  
50         String[] badStrs = badStr.split("\\|");  
51         for (int i = 0; i < badStrs.length; i++) {
52             if (str.indexOf(badStrs[i]) !=-1) { 
53                 System.out.println("匹配到:"+badStrs[i]);
54                 return true;  
55             }  
56         }  
57         return false;  
58     }  
59   
60     public void init(FilterConfig filterConfig) throws ServletException {  
61         //throw new UnsupportedOperationException("Not supported yet.");  
62     }  
63   
64     public void destroy() {  
65         //throw new UnsupportedOperationException("Not supported yet.");  
66     }  
67 }  

注意上面第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關鍵詞跳轉到的頁面):服務器

<%@ 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>

 

 

將上面的過濾器加入到本身的項目中能夠簡單地防止SQL注入,嚴格防止注入還需採起更有效的措施app

同理,咱們也可使用過濾器實現敏感詞的屏蔽功能,用法和防止SQL注入相似,自行探索!

 

 

 


 我是分割線


 

 

更多防範SQL注入的措施:

  1. 對輸入進行嚴格的限制和過濾
  2. 對一些應用如數據庫的鏈接進行有效的IP限定
  3. 儘量減小CGI程序中的系統調用
  4. 使用web掃描器預先掃描系統
  5. 下載SQL通用防注入系統的程序,在須要防範注入的頁面頭部用<!--# include file=」xxx.asp」-- >來防止別人進行手動注入測試 (針對asp網頁)
  6. 設置陷阱帳號:設置兩個賬號,一個是普通管理員賬號,一個是防注入的賬號。將防注入的帳號設置的很象管理員,如 admin,以製造假象吸引軟件的檢測,而密碼是大於千字以上的中文字符,迫使軟件分析帳號的時候進入全負荷狀態甚至資源耗盡而死機。 
相關文章
相關標籤/搜索