JSP使用過濾器防止SQL注入

來源:互聯網
上載者:User

標籤:

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

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

SQL注入攻擊指的是通過構建特殊的輸入作為參數傳入Web應用程式,而這些輸入大都是SQL文法裡的一些組合,通過執行SQL語句進而執行攻擊者所要的操作,其主要原因是程式沒有細緻地過濾使用者輸入的資料,致使非法資料侵入系統。

filter功能:

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

在一個request到達servlet之前預先處理request,也可以在離開 servlet時處理response.

換種說法,filter其實是一個”servlet chaining”(servlet 鏈). 所以使用者發出的任何request都必然經過filter處理,我們就在filter處理使用者request包含的敏感關鍵字,然後replace掉或是讓頁面轉到錯誤頁來提示使用者,這樣就可以很好的防sql注入了。

具體實現代碼:

/YourProject/src/com/SqlFilter.java

 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 }  

/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注入。

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

 

 我是分割線

 

更多防範SQL注入的措施:

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

  

JSP使用過濾器防止SQL注入

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.