Private keys are generated randomly in keyspace 8000000000000000000000000000000000000000:ffffffffffffffffffffffffffffffffffffffff the private keys are converted into their respective public keys to address and checks their balance in real-time.
Python 3.6 or higher
btc-hack.py will try to automatically install the required modules if they are not present. Should that fail, you can find the required modules listed in the requirements.txt
Minimum RAM requirements
$ git clone https://github.com/DarkMeArk/puzzle64
$ python3 puzzle64.py
Every time this program checks the balance of a generated address, it will print the result to the user. If an empty wallet is found, then the wallet address will be printed to the terminal. An example is:
1HBL9rXLrF1BoPwmLZHxuYV1wx4g6K32N6 : 0.0
However, if a wallet with a balance is found, then all necessary information about the wallet will be saved to the text file found.txt
. An example is:
address: 1B1Enw49ovsH3bReGbBnAfkfaGhaRJj3ku
private key: 00000000000000000000000000000000000000000000000090e15e21125e3806
WIF private key: 5HpHagT65TZzG1PH3CSu63k8DbpvD8s5ip7WoQYQFx7wjw8RaHL
public key: 037D5B40E63C41A0B70D499A41C8F256569BD4BF169B5E02D668BB0498C7178CEA
balance: 0.64
This program uses approximately 2GB of RAM per CPU. Because this program can use multi-processing, some data gets shared between threads making it difficult to accurately measure RAM usage.
The memory consumption stack trace was made by using mprof to monitor this program brute force 10,000 addresses on a 4 logical processor machine with 8GB of RAM. As a result, 4 child processes were created, each consuming 2100MiB of RAM (~2GB).