Thursday, 11 June 2020

ASIS CTF Quals 2015 - Sawthis Writeup - Srand Remote Prediction

Posted on 15:24 by Mordiadi


The remote service ask for a name, if you send more than 64 bytes, a memory leak happens.
The buffer next to the name's is the first random value used to init the srand()


If we get this value, and set our local srand([leaked] ^ [luckyNumber]) we will be able to predict the following randoms and win the game, but we have to see few details more ;)

The function used to read the input until the byte \n appears, but also up to 64 bytes, if we trigger this second condition there is not 0x00 and the print shows the random buffer :)

The nickname buffer:



The seed buffer:



So here it is clear, but let's see that the random values are computed with several gpu instructions which are decompiled incorrectly:







We tried to predict the random and aply the gpu divisions without luck :(



There was a missing detail in this predcitor, but there are always other creative ways to do the things.
We use the local software as a predictor, we inject the leaked seed on the local binary of the remote server and got a perfect syncronization, predicting the remote random values:




The process is a bit ugly becouse we combined automated process of leak exctraction and socket interactive mode, with the manual gdb macro.




The macro:



















Related articles

  1. Hacker Google
  2. Pentest Open Source
  3. Pentest With Metasploit
  4. Pentesterlab
  5. Hacking Books
  6. Hacking Apps
  7. Pentest Owasp Top 10
  8. Pentester Academy
  9. Hacking Apps
  10. Pentest With Kali Linux
  11. Hacker News
  12. Pentest Keys
  13. Pentest Basics

No Response to "ASIS CTF Quals 2015 - Sawthis Writeup - Srand Remote Prediction"

Leave A Reply

BTC

Doge

LTC

BCH

DASH

Tokens

SAMPAI JUMPA LAGI

SEMOGA ANDA MEMPEROLEH SESUATU YANG BERGUNA