濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > JSP使用過(guò)濾器防止SQL注入的簡(jiǎn)單實(shí)現(xiàn)

JSP使用過(guò)濾器防止SQL注入的簡(jiǎn)單實(shí)現(xiàn)

熱門標(biāo)簽:泰州泰興400電話 怎么申請(qǐng) 企業(yè)怎么在聯(lián)通申請(qǐng)400電話 百度地圖添加標(biāo)注圖標(biāo)樣式 聊城智能電銷機(jī)器人外呼 好操作的電話機(jī)器人廠家 南昌市地圖標(biāo)注app 南京新思維電話機(jī)器人 地圖標(biāo)注市場(chǎng)怎么樣 如何用中國(guó)地圖標(biāo)注數(shù)字點(diǎn)

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

sql注入_百度百科:

所謂SQL注入,就是通過(guò)把SQL命令插入到Web表單提交或輸入域名或頁(yè)面請(qǐng)求的查詢字符串,最終達(dá)到欺騙服務(wù)器執(zhí)行惡意的SQL命令。具體來(lái)說(shuō),它是利用現(xiàn)有應(yīng)用程序,將(惡意)的SQL命令注入到后臺(tái)數(shù)據(jù)庫(kù)引擎執(zhí)行的能力,它可以通過(guò)在Web表單中輸入(惡意)SQL語(yǔ)句得到一個(gè)存在安全漏洞的網(wǎng)站上的數(shù)據(jù)庫(kù),而不是按照設(shè)計(jì)者意圖去執(zhí)行SQL語(yǔ)句。[1]  比如先前的很多影視網(wǎng)站泄露VIP會(huì)員密碼大多就是通過(guò)WEB表單遞交查詢字符暴出的,這類表單特別容易受到SQL注入式攻擊.

SQL注入攻擊指的是通過(guò)構(gòu)建特殊的輸入作為參數(shù)傳入Web應(yīng)用程序,而這些輸入大都是SQL語(yǔ)法里的一些組合,通過(guò)執(zhí)行SQL語(yǔ)句進(jìn)而執(zhí)行攻擊者所要的操作,其主要原因是程序沒(méi)有細(xì)致地過(guò)濾用戶輸入的數(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.

換種說(shuō)法,filter其實(shí)是一個(gè)”servlet chaining”(servlet 鏈). 所以用戶發(fā)出的任何request都必然經(jīng)過(guò)filter處理,我們就在filter處理用戶request包含的敏感關(guān)鍵字,然后replace掉或是讓頁(yè)面轉(zhuǎn)到錯(cuò)誤頁(yè)來(lái)提示用戶,這樣就可以很好的防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; 
 
//過(guò)濾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|//|/|%|#";  */  //過(guò)濾掉的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中過(guò)濾器添加過(guò)濾器配置):

!-- 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(檢測(cè)到sql關(guān)鍵詞跳轉(zhuǎn)到的頁(yè)面):

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

將上面的過(guò)濾器加入到自己的項(xiàng)目中可以簡(jiǎn)單地防止SQL注入,嚴(yán)格防止注入還需采取更有效的措施。

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

 我是分割線

-----------------------------------------

更多防范SQL注入的措施:

1.對(duì)輸入進(jìn)行嚴(yán)格的限制和過(guò)濾

2.對(duì)一些應(yīng)用如數(shù)據(jù)庫(kù)的連接進(jìn)行有效的IP限定

3.盡可能減少CGI程序中的系統(tǒng)調(diào)用

4.使用web掃描器預(yù)先掃描系統(tǒng)

5.下載SQL通用防注入系統(tǒng)的程序,在需要防范注入的頁(yè)面頭部用!--# include file=”xxx.asp”-- >來(lái)防止別人進(jìn)行手動(dòng)注入測(cè)試 (針對(duì)asp網(wǎng)頁(yè))

6.設(shè)置陷阱賬號(hào):設(shè)置兩個(gè)帳號(hào),一個(gè)是普通管理員帳號(hào),一個(gè)是防注入的帳號(hào)。將防注入的賬號(hào)設(shè)置的很象管理員,如 admin,以制造假象吸引軟件的檢測(cè),而密碼是大于千字以上的中文字符,迫使軟件分析賬號(hào)的時(shí)候進(jìn)入全負(fù)荷狀態(tài)甚至資源耗盡而死機(jī)。

以上這篇JSP使用過(guò)濾器防止SQL注入的簡(jiǎn)單實(shí)現(xiàn)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 通過(guò)過(guò)濾器(Filter)解決JSP的Post和Request中文亂碼問(wèn)題
  • JSP過(guò)濾器Filter配置過(guò)濾類型全部匯總
  • JSP 開發(fā)中過(guò)濾器filter設(shè)置編碼格式的實(shí)現(xiàn)方法
  • JSP使用Servlet過(guò)濾器進(jìn)行身份驗(yàn)證的方法
  • JSP過(guò)濾器防止Xss漏洞的實(shí)現(xiàn)方法(分享)
  • jsp實(shí)現(xiàn)登錄驗(yàn)證的過(guò)濾器
  • jsp中過(guò)濾器選擇過(guò)濾器的寫法詳解
  • 詳解JSP中使用過(guò)濾器進(jìn)行內(nèi)容編碼的解決辦法
  • servlet+jsp實(shí)現(xiàn)過(guò)濾器 防止用戶未登錄訪問(wèn)
  • JSP使用過(guò)濾器防止Xss漏洞
  • jsp filter 過(guò)濾器功能與簡(jiǎn)單用法示例

標(biāo)簽:自貢 開封 銅川 白銀 山南 吉林 烏蘭察布 臨汾

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《JSP使用過(guò)濾器防止SQL注入的簡(jiǎn)單實(shí)現(xiàn)》,本文關(guān)鍵詞  JSP,使用,過(guò)濾器,防止,SQL,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《JSP使用過(guò)濾器防止SQL注入的簡(jiǎn)單實(shí)現(xiàn)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于JSP使用過(guò)濾器防止SQL注入的簡(jiǎn)單實(shí)現(xiàn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    霍山县| 翁牛特旗| 保定市| 沁水县| 黎川县| 南丹县| 梧州市| 东安县| 嘉兴市| 盘锦市| 米泉市| 新绛县| 轮台县| 长垣县| 吴桥县| 营山县| 海安县| 英吉沙县| 建德市| 荔浦县| 巴中市| 渭南市| 嘉峪关市| 郧西县| 巫溪县| 太康县| 南投市| 高清| 鄂托克旗| 杨浦区| 鹰潭市| 南乐县| 上杭县| 兰考县| 无锡市| 田林县| 宜都市| 乐亭县| 即墨市| 达州市| 顺义区|