|
php注入實例在網上很難看到一篇完整的關于php注入的文章和利用代碼,于是我自已把mysql和php硬啃了幾個星期,下面說說我的休會吧,希望能拋磚引玉!
相信大家對ASP的注入已經是十分熟悉了,而對php的注入比ASP要困難,因為php的magic_gpc選項確實讓人頭疼,在注入中不要出現引號,而php大多和mysql結合,而mysql的功能上的缺點,從另外一人角度看確在一定程度上防止了sql njection的攻擊,我在這里就舉一個實例吧,我以phpbb2.0為例:
在viewforum.php中有一個變量沒過濾:
if ( isset($HTTP_GET_VARS<pOST_FORUM_URL]) ││ isset($HTTP_POST_VARS<pOST_FORUM_URL]) )
{
$forum_id = ( isset($HTTP_GET_VARS<pOST_FORUM_URL]) ) ? intval($HTTP_GET_VARS<pOST_FORUM_URL]): intval
($HTTP_POST_VARS<pOST_FORUM_URL]);
}
else if ( isset($HTTP_GET_VARS['forum']))
{
$forum_id = $HTTP_GET_VARS['forum'];
}
else
{
$forum_id = '';
}
就是這個forum,而下面直接把它放進了查詢中:
if ( !empty($forum_id) )
{
$sql = "SELECT *
FROM " . FORUMS_TABLE . "
WHERE forum_id = $forum_id";
if ( !($result = $db->sql_query($sql)) )
{
message_die(GENERAL_ERROR, 'Could not obtain forums information', '', __LINE__, __FILE__, $sql);
}
}
else
{
message_die(GENERAL_MESSAGE, 'Forum_not_exist');
}
如果是ASP的話,相信很多人都會注入了.如果這個forum_id指定的論壇不存在的話,就會使$result為空,于是返回Could not obtain forums information的信息,于是下面的代碼就不能執行下去了
//
// If the query doesn't return any rows this isn't a valid forum. Inform
// the user.
//
if ( !($forum_row = $db->sql_fetchrow($result)) )
{
message_die(GENERAL_MESSAGE, 'Forum_not_exist');
}
//
// Start session management
//
$userdata = session_pagestart($user_ip, $forum_id) /****************************************
關鍵就是打星號的那一行了,這里是一個函數session_pagestart($user_ip, $thispage_id),這是在session.php中定義的一個函數,由于代碼太
長,就不全貼出來了,有興趣的可以自已看看,關鍵是這個函數還調用了session_begin(),函數調用如下session_begin($user_id, $user_ip,
$thispage_id, TRUE)),同樣是在這個文件中定義的,其中有如下代碼
$sql = "UPDATE " . SESSIONS_TABLE . "
SET session_user_id = $user_id, session_start = $current_time, session_time = $current_time, session_page =
$page_id, session_logged_in = $login
WHERE session_id = '" . $session_id . "'
AND session_ip = '$user_ip'";
if ( !($result = $db->sql_query($sql)) ││ !$db->sql_affectedrows() )
{
$session_id = md5(uniqid($user_ip));
$sql = "INSERT INTO " . SESSIONS_TABLE . "
(session_id, session_user_id, session_start, session_time, session_ip, session_page,
session_logged_in)
VALUES ('$session_id', $user_id, $current_time, $current_time, '$user_ip', $page_id, $login)";
if ( !($result = $db->sql_query($sql)) )
{
message_die(CRITICAL_ERROR, 'Error creating new session : session_begin', '', __LINE__, __FILE__,
$sql);
}
在這里有個session_page在mysql中定義的是個整形數,他的 主站蜘蛛池模板: 亚洲成A人片在线观看中文L | 老阿姨才是最有味的一区二区 | gogogo免费视频观看 | 在线视频a | 亚洲精品国产精品精 | 国产乱码伦人偷精品视频 | 亚洲 天堂 国产在线播放 | 亚洲国产日韩欧美高清片a 亚洲国产日韩a精品乱码 | 日本精品久久久久中文字幕 | 色狗综合网 | 国产午夜精品视频在线播放 | 18未满不能进的福利社 | 国产精品你懂的在线播放 | 亚洲AV 无码AV 中文字幕 | 久久这里只有精品1 | 日韩影院久久 | 在线国产a不卡 | 国产综合视频在线观看一区 | 久久久GOGO无码啪啪艺术 | 茎身铃口调教 | 欧洲精品一区二区不卡观看 | 人曽交Z00Z0OA片 | 古装性艳史电影在线看 | 三级网址在线播放 | 国产精品自产拍在线观看中文 | 男生扒开美女尿口戳戳 | 91天仙tv嫩模福利 | 99日韩精品 | www.久艹| 国产亚洲精品黑人粗大精选 | 干性感美女| 国语自产视频在线不卡 | 人人模人人干 | 亚洲精品久久无码AV片WWW | 老妇xxxxbbbb| 三级黄在线播放 | china中国gay偷拍 | 全黄h全肉短篇禁乱np | 99久久综合| 国产精品成人影院在线观看 | 无套内射在线观看THEPORN |