Классическую удаленную уязвимость форматирующей строки можно найти в версиях программы rwhoisd 1.5.7.1 и более ранних. Она позволяла удаленному злоумышленнику после подключения к серверу выполнить произвольный код. Впервые об уязвимости стало известно благодаря сообщению списка рассылки Bugtraq. Заархивированное сообщение может быть найдено по адресу www.securityfocus.com/archive/1/222756.
Для того чтобы понять уязвимость форматирующей строки программы rwhoisd, следует внимательно изучить ее исходный текст. В главе рассмотрена версия программы 1.5.7.1. На момент написания книги ее можно было загрузить по адресу www.rwhois.net/ftp.
Уязвимость проявляется во время вывода сообщения об ошибке при неверном задании аргумента команды – soa
в командной строке.Сообщение об ошибке формируется и выводится функцией
Исходный текст этой функции может быть найден в файле
/* prints to stdout the error messages. Format: %error ### message
text, where ### follows rfc 640 */
void
print_error(va_alist)
va_dcl
{
va_list list;
int i;
int err_no;
char *format;
if (printed_error_flag)
{
return;
}
va_start(list);
err_no = va_arg(list, int);
for (i = 0; i < N_ERRS; i++)
{
if (errs[i].err_no == err_no)
{
printf(“%%error %s”, errs[i].msg);
break;
}
}
format = va_arg(list, char*);
if (*format)
{
printf(“: ”);
}
vprintf(format, list);
va_end(list);
printf(“\n”);
printed_error_flag = TRUE;
}В исходном тексте жирным шрифтом отмечено место передачи входных данных программы функции
В примере рассматривается функция
Рассмотрим, что произойдет, когда клиент подключится к сервису и попытается подсунуть функции
..
auth_area = find_auth_area_by_name(argv[i]);
if (!auth_area)
{
print_error(INVALID_AUTH_AREA, argv[i]);
free_arg_list(argv);
dl_list_destroy(soa_arg);
return NULL;
}