亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JSP > 正文

JSP使用過濾器防止SQL注入的簡單實現

2024-09-05 00:22:37
字體:
來源:轉載
供稿:網友

什么是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注入的簡單實現就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JSP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
最近2019中文字幕在线高清| 国产精品欧美激情在线播放| 精品日韩美女的视频高清| 国产精品偷伦免费视频观看的| 精品久久久久久久久中文字幕| 7777免费精品视频| 亚洲a一级视频| 久久精品国产一区二区三区| 国内精品久久久久久中文字幕| 精品国产户外野外| 欧美日韩国内自拍| 欧美极品少妇与黑人| 久久久久免费视频| 亚洲欧美精品一区二区| 久久综合色影院| 午夜精品久久久久久久99热浪潮| 精品夜色国产国偷在线| 国产欧美精品xxxx另类| 俺也去精品视频在线观看| 日本成人精品在线| 亚洲男人天堂2019| 久久久久久久999| 色黄久久久久久| 91精品国产综合久久香蕉最新版| 国产欧美精品va在线观看| 欧美激情第1页| 一区二区三区动漫| 亚洲欧美色图片| 裸体女人亚洲精品一区| 欧美激情videos| 亚洲综合日韩中文字幕v在线| 中文国产成人精品久久一| 欧美大奶子在线| 91中文在线观看| 亚洲视频电影图片偷拍一区| 日韩hd视频在线观看| 欧美日韩一区二区免费在线观看| 欧美贵妇videos办公室| 北条麻妃在线一区二区| 国产精品日本精品| 国产成人拍精品视频午夜网站| 91精品国产综合久久久久久蜜臀| 亚洲午夜国产成人av电影男同| 亚洲jizzjizz日本少妇| 日韩av色综合| 国产一区二中文字幕在线看| 久久91亚洲人成电影网站| 国产成人涩涩涩视频在线观看| 欧美一级免费看| 日韩一区视频在线| 久久精品国产一区| 欧美三级欧美成人高清www| www.欧美精品一二三区| 亚洲人成电影网站色www| 欧美一级大片在线免费观看| 国产99久久精品一区二区永久免费| 亚洲欧洲免费视频| 午夜精品久久久久久99热| 精品美女国产在线| 久99九色视频在线观看| 久久久免费观看| 欧美亚洲伦理www| 国产精品扒开腿做爽爽爽的视频| 成人福利网站在线观看11| 伊人久久久久久久久久| 国产精品久久久久久亚洲调教| 精品在线欧美视频| 欧美性猛交xxxx偷拍洗澡| 动漫精品一区二区| 91精品久久久久| 亚洲97在线观看| 久久大大胆人体| 大伊人狠狠躁夜夜躁av一区| 成人黄色av播放免费| 深夜福利亚洲导航| 久久免费视频在线观看| 国产啪精品视频网站| 日韩av影院在线观看| 欧美色道久久88综合亚洲精品| 欧美怡春院一区二区三区| 中文字幕国产精品| 中文字幕亚洲激情| 精品久久久久国产| 日韩成人中文电影| 久久伊人91精品综合网站| 久久综合免费视频| 日韩麻豆第一页| 日韩中文视频免费在线观看| 青草成人免费视频| 91视频88av| 国产第一区电影| 国产一区二区三区三区在线观看| 亚洲精品国产成人| 亚洲欧美日韩中文视频| 97精品久久久中文字幕免费| 亚洲精品一区中文字幕乱码| 亚洲乱码一区二区| 亚洲国产91精品在线观看| 粉嫩老牛aⅴ一区二区三区| 日本午夜在线亚洲.国产| 亚洲一区www| 欧美尺度大的性做爰视频| 久色乳综合思思在线视频| 久久人人爽人人| 欧美日韩国产一中文字不卡| 久久精品91久久久久久再现| 91精品国产高清自在线看超| 亚洲国产精品系列| 亚洲在线免费看| 97精品一区二区视频在线观看| 日韩成人在线免费观看| 91国产精品电影| 国产日韩欧美在线播放| 26uuu日韩精品一区二区| 国产日韩亚洲欧美| 欧美成人免费大片| 91精品综合视频| 国产精品色婷婷视频| 国产精品久久久久久久久| 免费成人高清视频| 国产精品日韩在线观看| www.精品av.com| 精品女厕一区二区三区| 成人乱人伦精品视频在线观看| 久色乳综合思思在线视频| 一区二区中文字幕| 狠狠躁天天躁日日躁欧美| 亚洲人线精品午夜| 91在线无精精品一区二区| 亚洲一区二区三区四区视频| 亚洲欧美另类人妖| 欧美有码在线观看视频| 九九九久久久久久| 国产精品91久久久久久| 国产专区欧美专区| 色黄久久久久久| 日本不卡视频在线播放| 中文字幕在线成人| 欧美性极品少妇精品网站| 久久精品国产亚洲7777| 成人美女免费网站视频| 欧美裸体xxxxx| 亚洲午夜未满十八勿入免费观看全集| 亚洲精美色品网站| 国产丝袜精品第一页| 欧美精品www在线观看| 欧美激情亚洲一区| 欧美性猛交xxxx乱大交| 海角国产乱辈乱精品视频| 久久99亚洲精品| 国产不卡av在线| 在线看国产精品| 久久精品中文字幕免费mv| 欧美香蕉大胸在线视频观看| 国产视频福利一区| 都市激情亚洲色图| 亚洲天堂视频在线观看| 成人国产精品久久久| 国产精品丝袜久久久久久不卡| 中文字幕在线日韩| 亚洲综合在线做性| 日本中文字幕成人| 91精品久久久久久久久久入口| 久久久亚洲成人|