boblog任意变量覆盖漏洞

所属分类: 网络安全 / 漏洞分析 阅读数: 221
收藏 0 赞 0 分享

  漏洞代码如下:

  // go.php

  $q_url=$_SERVER["REQUEST_URI"];

  @list($relativePath, $rawURL)=@explode('/go.php/', $q_url);

  $rewritedURL=$rawURL; // 来自$_SERVER["REQUEST_URI"],可以任意提交的:)

  ...

  $RewriteRules[]="/component/([^/]+)/?/";

  // 这个正则限制的不够细致,可以很轻易的绕过:)

  ...

  $RedirectTo[]="page.php?pagealias=\1";

  $i=0;

  foreach ($RewriteRules as $rule) {

  if (preg_match($rule, $rewritedURL)) {

  $tmp_rewritedURL=preg_replace($rule, '<'.$RedirectTo[$i].'<', $rewritedURL, 1);

  $tmp_rewritedURL=@explode('<', $tmp_rewritedURL);

  $rewritedURL=($tmp_rewritedURL[2]) ? false : $tmp_rewritedURL[1];

  break;

  }

  $i+=1;

  }

  if ($rewritedURL==$rawURL || !$rewritedURL) {

  ...

  $parsedURL=parse_url ($rewritedURL);

  // 这里的$parsedURL['query']就是要利用的变量了:)

  parse_str($parsedURL['query']);

  // 通过这个地方可以覆盖任意变量

  include(basename($parsedURL['path']));

  // 通过上面的覆盖,可以利用这里包含本地文件,不过用了basename()函数处理:(

  这个漏洞不是很复杂,关键说说利用,这里有两个利用点,一个覆盖,一个利用覆盖来包含,虽然用了basename()来限制,但是可以利用data://来执行命令.只是这种方式的利用是有限制的[PHP>5.2.0&allow_url_include=On].不过没关系,还有更好的利用方式

  来看下global.php文件:

  ...

  unregister_GLOBALS(); //When register_globals=On

  ...

  function unregister_GLOBALS() { //When register_globals = 'on'

  if (!ini_get('register_globals')) { //Already off

  return;

  }

  // Variables that shouldn't be unset

  $noUnset = array('_GET', '_POST', '_COOKIE', '_REQUEST', '_SERVER', '_ENV', '_FILES');

  $input = array_merge($_GET, $_POST, $_COOKIE, $_SERVER, $_ENV, $_FILES, isset($_SESSION) && is_array($_SESSION) ? $_SESSION : array());

  foreach ($input as $k => $v) {

  if ($k=='GLOBALS') {

  global $kgr;

  $kgr=0;

  kill_GLOBALS($input[$k]); //GLOBALS is recursive -,-

  }

  elseif (!in_array($k, $noUnset) && isset($GLOBALS[$k])) {

  $GLOBALS[$k]=NULL;

  }

  }

  }

  在这里取消了全局变量,但是我们可以通过go.php中的覆盖变量和包含文件来绕过unregister_GLOBALS()的限制,触发变量未初始化漏洞,这将导致xss、sql注射、命令执行等众多严重的安全问题。

更多精彩内容其他人还在看

万能密码漏洞以及修复

  万能密码漏洞以及修复   记得几年前要入侵一个企业网站超级简单   一般只需要找到后台 还有后台通常是www.xxx.com/admin/   然后账号 密码都是'or'='or' 就进去   现在好像有几个也可以用 但是已经没那么普及了   如果网站还出现这种“
收藏 0 赞 0 分享

cyask知道系统collect.php页面存在越权漏洞

影响版本: Cyask 程序介绍: Cyask国内较为多人使用的仿百度风格的Ask系统。 漏洞分析: 从Collect.php代码当中可以看到 else   {     /*  
收藏 0 赞 0 分享

恒浪IMS整合系统V4.1 多文件存在SQL注入漏洞

影响版本: HoWave V4.1 ASP 漏洞描述: 在文件inc/ hl_manage.inc中: adminUserId= Request.Cookies("hl_manage")("username")  
收藏 0 赞 0 分享

WINDOWS 7 RC 7100 GDI驱动Win32k.sys内核D.O.S漏洞

感谢:Iceboy发现此问题并提供DUMP 漏洞厂商及产品:Microsoft Windows 7 rc 7100 090421 存在漏洞组件:win32k.sys Timestamp :49ee8dc8 存在漏洞函数:NtUserGetDc/NtUserGetDcEx 漏洞描
收藏 0 赞 0 分享

Gh0st控制端逻辑漏洞

严重程度:高 威胁程度:控制远程主机 错误类型:逻辑错误 利用方式:主机模式   受影响系统 Gh0st3.6之前所有版本 未影响系统 未知 详细描述 Gh0st 发现漏洞一个逻辑漏洞,这些漏洞可以被用户利用,可以从被控端向控制端发送任意文件到任意位置。 测试
收藏 0 赞 0 分享

微软IIS6漏洞:服务器敏感信息易被窃

近日,安全专家对使用微软Internet信息服务IIS 6的管理员发出警告,声称Web服务器很容易受到攻击并暴露出密码保护的文件和文件夹。   据悉,基于WebDAV协议的部分进程命令中存在这种漏洞。通过给Web地址添加一些Unicode字符,黑客就可以访问这些敏感文件&mda
收藏 0 赞 0 分享

校内网最新 xss Cookies得到密码

From:http://t00ls.net/viewthread.php?tid=1323&highlight= 校内网在发blog时对插入图片过滤不严格,存在xss漏洞. 在发blog时将插入图片URL写为如下代码即可触发:普通浏览复制代码打印代码 javas
收藏 0 赞 0 分享

phpcms2008 注入漏洞

这个是最新有人发现的 该漏洞文件:ask/search_ajax.php 漏洞说明: /ask/search_ajax.php Code: if($q) { $where = " title LIKE '%$q%' AND status = 5&qu
收藏 0 赞 0 分享

PHPWIND & DISCUZ! CSRF漏洞

PHPWIND & DISCUZ! CSRF漏洞影响版本: Discuz! 6.0.0 & 6.1.0 & 7.0.0 PHPWIND 6.0 & 6.3 & 7.0 漏洞描述: PHPWIND & DISCUZ!存在CSRF漏洞
收藏 0 赞 0 分享

phpwin7.0拿shell的方法

事发一星期前,在入侵一个PHPWIND论坛时的成果,适用于PHPWIND不能上传,而网上盛传的三种拿SEHLL方法都无效,可以一试,应该算是PHPWIND后台的漏洞 准备工具:winsock专家 v0.6 betan1 一只;UE-32.EXE一只;NC.EXE一只,电脑一台(
收藏 0 赞 0 分享
查看更多