php中常見的sql攻擊正則表達(dá)式匯總
本文實(shí)例講述了php中常見的sql攻擊正則表達(dá)式。分享給大家供大家參考。具體分析如下:
我們都已經(jīng)知道,在MYSQL 5+中 information_schema庫中存儲(chǔ)了所有的 庫名,表明以及字段名信息。故攻擊方式如下:
1. 判斷第一個(gè)表名的第一個(gè)字符是否是a-z中的字符,其中blind_sqli是假設(shè)已知的庫名。
注:正則表達(dá)式中 ^[a-z] 表示字符串中開始字符是在 a-z范圍內(nèi)
2. 判斷第一個(gè)字符是否是a-n中的字符
3. 確定該字符為n
4. 表達(dá)式的更換如下
這時(shí)說明表名為news ,要驗(yàn)證是否是該表明 正則表達(dá)式為'^news$',但是沒這必要 直接判斷 table_name = 'news‘ 不就行了。
5.接下來猜解其它表了 只需要修改 limit 1,1 -> limit 2,1就可以對接下來的表進(jìn)行盲注了。
例如:
$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攻擊代碼:
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>操作時(shí)間: ".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分析:
如果使用這個(gè)函數(shù)的話,這個(gè)函數(shù)會(huì)繞開PHP的標(biāo)準(zhǔn)出錯(cuò)處理,所以說得自己定義報(bào)錯(cuò)處理程序(die())。
其次,如果代碼執(zhí)行前就發(fā)生了錯(cuò)誤,那個(gè)時(shí)候用戶自定義的程序還沒有執(zhí)行,所以就不會(huì)用到用戶自己寫的報(bào)錯(cuò)處理程序?!?/p>
那么,PHP里有一套錯(cuò)誤處理機(jī)制,可以使用set_error_handler()接管PHP錯(cuò)誤處理,也可以使用trigger_error()函數(shù)主動(dòng)拋出一個(gè)錯(cuò)誤。
set_error_handler()函數(shù)設(shè)置用戶自定義的錯(cuò)誤處理函數(shù)。函數(shù)用于創(chuàng)建運(yùn)行期間的用戶自己的錯(cuò)誤處理方法。它需要先創(chuàng)建一個(gè)錯(cuò)誤處理函數(shù),然后設(shè)置錯(cuò)誤級別?! ?br />
關(guān)于的用法:
{
echo "<b>錯(cuò)誤代碼:</b> [${errno}] ${errstr}\r\n";
echo " 錯(cuò)誤所在的代碼行: {$errline} 文件{$errfile}\r\n";
echo " PHP版本 ",PHP_VERSION, "(" , PHP_OS, ")\r\n";
// die();
}
set_error_handler("customError",E_ALL| E_STRICT);
總結(jié)
PHP遇到錯(cuò)誤時(shí),就會(huì)給出出錯(cuò)腳本的位置、行數(shù)和原因,有很多人說,這并沒有什么大不了。但泄露了實(shí)際路徑的后果是不堪設(shè)想的,對于某些入侵者,這個(gè)信息可是非常重要,而事實(shí)上現(xiàn)在有很多的服務(wù)器都存在這個(gè)問題。 有些網(wǎng)管干脆把PHP配置文件中的 display_errors 設(shè)置為 Off 來解決,但本人認(rèn)為這個(gè)方法過于消極。有些時(shí)候,我們的確需要PHP返回錯(cuò)誤的信息以便調(diào)試。而且在出錯(cuò)時(shí)也可能需要給用戶一個(gè)交待,甚至導(dǎo)航到另一頁面。但是有了set_error_handler()之后,這些矛盾也都可以解決掉了。但是發(fā)現(xiàn)很少用這個(gè)函數(shù)。
希望本文所述對大家的PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP中利用substr_replace將指定兩位置之間的字符替換為*號
PHP的substr_replace將指定兩位置之間的字符替換為*號的代碼,需要的朋友可以參考下。2011-01-01PHP中使用數(shù)組指針函數(shù)操作數(shù)組示例
這篇文章主要介紹了PHP中使用數(shù)組指針函數(shù)操作數(shù)組示例,本文講解了current()、key()、next()、prev()、end()、reset()等數(shù)組指針函數(shù),需要的朋友可以參考下2014-11-11Thinkphp框架安裝composer擴(kuò)展包流程梳理
這篇文章主要介紹了Thinkphp使用composer安裝擴(kuò)展包教程,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-09-09PHP調(diào)用Twitter的RSS的實(shí)現(xiàn)代碼
“守望軒”博客右側(cè)邊欄原來有個(gè)“雜感”的欄目,用來記錄短的、不能大篇幅成文的短句,或者自己比較喜歡的短句和言論。2010-03-03php使用變量動(dòng)態(tài)創(chuàng)建類的對象用法示例
這篇文章主要介紹了php使用變量動(dòng)態(tài)創(chuàng)建類的對象,涉及php面向?qū)ο蟪绦蛟O(shè)計(jì)中對象的動(dòng)態(tài)創(chuàng)建相關(guān)操作技巧,需要的朋友可以參考下2017-02-02