什么是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
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關鍵字的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;
//獲得所有請求參數名
Enumeration params = req.getParameterNames();
String sql = "";
while (params.hasMoreElements()) {
//得到參數名
String name = params.nextElement().toString();
//System.out.println("name===========================" + name + "--");
//得到參數對應值
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);
}
}
//校驗
protected static boolean sqlValidate(String str) {
str = str.toLowerCase();//統一轉為小寫
//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關鍵字,可以手動添加
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關鍵詞跳轉到的頁面):
%@ 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注入的簡單實現就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 通過過濾器(Filter)解決JSP的Post和Request中文亂碼問題
- JSP過濾器Filter配置過濾類型全部匯總
- JSP 開發中過濾器filter設置編碼格式的實現方法
- JSP使用Servlet過濾器進行身份驗證的方法
- JSP過濾器防止Xss漏洞的實現方法(分享)
- jsp實現登錄驗證的過濾器
- jsp中過濾器選擇過濾器的寫法詳解
- 詳解JSP中使用過濾器進行內容編碼的解決辦法
- servlet+jsp實現過濾器 防止用戶未登錄訪問
- JSP使用過濾器防止Xss漏洞
- jsp filter 過濾器功能與簡單用法示例