亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

php中常見的sql攻擊正則表達(dá)式匯總

 更新時間:2014年11月06日 16:04:56   投稿:shichen2014  
這篇文章主要介紹了php中常見的sql攻擊正則表達(dá)式,實(shí)例匯總了針對各種常見的SQL語句及正則表達(dá)式原理的分析與應(yīng)用,對于PHP程序設(shè)計的安全來說具有很好的參考借鑒價值,需要的朋友可以參考下

本文實(shí)例講述了php中常見的sql攻擊正則表達(dá)式。分享給大家供大家參考。具體分析如下:

我們都已經(jīng)知道,在MYSQL 5+中 information_schema庫中存儲了所有的 庫名,表明以及字段名信息。故攻擊方式如下:

1. 判斷第一個表名的第一個字符是否是a-z中的字符,其中blind_sqli是假設(shè)已知的庫名。
注:正則表達(dá)式中 ^[a-z] 表示字符串中開始字符是在 a-z范圍內(nèi)

復(fù)制代碼 代碼如下:
index.php?id=1 and 1=(SELECT 1 FROM information_schema.tables WHERE TABLE_SCHEMA="blind_sqli" AND table_name REGEXP '^[a-z]' LIMIT 0,1) /*

2. 判斷第一個字符是否是a-n中的字符

復(fù)制代碼 代碼如下:
index.php?id=1 and 1=(SELECT 1 FROM information_schema.tables  WHERE TABLE_SCHEMA="blind_sqli" AND table_name REGEXP '^[a-n]' LIMIT 0,1)/*

3. 確定該字符為n

復(fù)制代碼 代碼如下:
index.php?id=1 and 1=(SELECT 1 FROM information_schema.tables  WHERE TABLE_SCHEMA="blind_sqli" AND table_name REGEXP '^n' LIMIT 0,1) /*

4. 表達(dá)式的更換如下

復(fù)制代碼 代碼如下:
expression like this:  '^n[a-z]' -> '^ne[a-z]' -> '^new[a-z]' -> '^news[a-z]' -> FALSE

這時說明表名為news ,要驗(yàn)證是否是該表明 正則表達(dá)式為'^news$',但是沒這必要 直接判斷 table_name = 'news‘ 不就行了。

5.接下來猜解其它表了 只需要修改 limit 1,1 -> limit 2,1就可以對接下來的表進(jìn)行盲注了。

例如:

復(fù)制代碼 代碼如下:
$Exec_Commond  = "( \s|\S)*(exec(\s|\+)+(s|x)p\w+)(\s|\S)*";
$Simple_XSS = "( \s|\S)*((%3C)|<)((%2F)|/)*[a-z0-9%]+((%3E)|>)(\s|\S)*";
$Eval_XSS  = "( \s|\S)*((%65)|e)(\s)*((%76)|v)(\s)*((%61)|a)(\s)*((%6C)|l)(\s|\S)*";
$Image_XSS  = "( \s|\S)*((%3C)|<)((%69)|i|I|(%49))((%6D)|m|M|(%4D))((%67)|g|G|(%47))[^\n]+((%3E)|>)(\s|\S)*" ;
$Script_XSS = "( \s|\S)*((%73)|s)(\s)*((%63)|c)(\s)*((%72)|r)(\s)*((%69)|i)(\s)*((%70)|p)(\s)*((%74)|t)(\s|\S)*";
$SQL_Injection = "( \s|\S)*((%27)|(')|(%3D)|(=)|(/)|(%2F)|(")|((%22)|(-|%2D){2})|(%23)|(%3B)|(;))+(\s|\S)*";

sql攻擊代碼:

復(fù)制代碼 代碼如下:
<?php
function customError($errno, $errstr, $errfile, $errline)
{
    echo "<b>Error number:</b> [$errno],error on line $errline in $errfile<br />";
    die();
}
set_error_handler("customError",E_ERROR);
$getfilter="'|(and|or)\b.+?(>|<|=|in|like)|\/\*.+?\*\/|<\s*script\b|\bEXEC\b|UNION.+?SELECT|UPDATE.+?SET|INSERT\s+INTO.+?VALUES|(SELECT|DELETE).+?FROM|(CREATE|ALTER|DROP|TRUNCATE)\s+(TABLE|DATABASE)";
$postfilter="\b(and|or)\b.{1,6}?(=|>|<|\bin\b|\blike\b)|\/\*.+?\*\/|<\s*script\b|\bEXEC\b|UNION.+?SELECT|UPDATE.+?SET|INSERT\s+INTO.+?VALUES|(SELECT|DELETE).+?FROM|(CREATE|ALTER|DROP|TRUNCATE)\s+(TABLE|DATABASE)";
$cookiefilter="\b(and|or)\b.{1,6}?(=|>|<|\bin\b|\blike\b)|\/\*.+?\*\/|<\s*script\b|\bEXEC\b|UNION.+?SELECT|UPDATE.+?SET|INSERT\s+INTO.+?VALUES|(SELECT|DELETE).+?FROM|(CREATE|ALTER|DROP|TRUNCATE)\s+(TABLE|DATABASE)";
function StopAttack($StrFiltKey,$StrFiltValue,$ArrFiltReq)
{   
    if(is_array($StrFiltValue))
    {
        $StrFiltValue=implode($StrFiltValue);
    }
    if (preg_match("/".$ArrFiltReq."/is",$StrFiltValue)==1&&!isset($_REQUEST['securityToken']))
    {
        slog("<br><br>操作IP: ".$_SERVER["REMOTE_ADDR"]."<br>操作時間: ".strftime("%Y-%m-%d %H:%M:%S")."<br>操作頁面:".$_SERVER["PHP_SELF"]."<br>提交方式: ".$_SERVER["REQUEST_METHOD"]."<br>提交參數(shù): ".$StrFiltKey."<br>提交數(shù)據(jù): ".$StrFiltValue);
        print "result notice:Illegal operation!";
        exit();
    }
}
foreach($_GET as $key=>$value)
{
    StopAttack($key,$value,$getfilter);
}
foreach($_POST as $key=>$value)
{
    StopAttack($key,$value,$postfilter);
}
foreach($_COOKIE as $key=>$value)
{
    StopAttack($key,$value,$cookiefilter);
}
  
function slog($logs)
{
    $toppath="log.htm";
    $Ts=fopen($toppath,"a+");
    fputs($Ts,$logs."rn");
    fclose($Ts);
}
?>

sql分析:

如果使用這個函數(shù)的話,這個函數(shù)會繞開PHP的標(biāo)準(zhǔn)出錯處理,所以說得自己定義報錯處理程序(die())。
其次,如果代碼執(zhí)行前就發(fā)生了錯誤,那個時候用戶自定義的程序還沒有執(zhí)行,所以就不會用到用戶自己寫的報錯處理程序?!?/p>

那么,PHP里有一套錯誤處理機(jī)制,可以使用set_error_handler()接管PHP錯誤處理,也可以使用trigger_error()函數(shù)主動拋出一個錯誤。

set_error_handler()函數(shù)設(shè)置用戶自定義的錯誤處理函數(shù)。函數(shù)用于創(chuàng)建運(yùn)行期間的用戶自己的錯誤處理方法。它需要先創(chuàng)建一個錯誤處理函數(shù),然后設(shè)置錯誤級別。   
關(guān)于的用法:

復(fù)制代碼 代碼如下:
function customError($errno, $errstr, $errfile, $errline)
{
  echo "<b>錯誤代碼:</b> [${errno}] ${errstr}\r\n";
  echo " 錯誤所在的代碼行: {$errline} 文件{$errfile}\r\n";
   echo " PHP版本 ",PHP_VERSION, "(" , PHP_OS, ")\r\n";
  // die();
}
set_error_handler("customError",E_ALL| E_STRICT);

總結(jié)

PHP遇到錯誤時,就會給出出錯腳本的位置、行數(shù)和原因,有很多人說,這并沒有什么大不了。但泄露了實(shí)際路徑的后果是不堪設(shè)想的,對于某些入侵者,這個信息可是非常重要,而事實(shí)上現(xiàn)在有很多的服務(wù)器都存在這個問題。 有些網(wǎng)管干脆把PHP配置文件中的 display_errors 設(shè)置為 Off 來解決,但本人認(rèn)為這個方法過于消極。有些時候,我們的確需要PHP返回錯誤的信息以便調(diào)試。而且在出錯時也可能需要給用戶一個交待,甚至導(dǎo)航到另一頁面。但是有了set_error_handler()之后,這些矛盾也都可以解決掉了。但是發(fā)現(xiàn)很少用這個函數(shù)。

希望本文所述對大家的PHP程序設(shè)計有所幫助。

相關(guān)文章

最新評論