2026-01-23 08:48:08 +01:00
|
|
|
# Bitcoin P2PK Bruteforce
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
Strumento di ricerca chiavi private Bitcoin P2PK compilato per massime performance su CPU (fino a **300K+ keys/sec**).
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
**⚠️ DISCLAIMER**: Solo per scopi educativi e di ricerca. Non utilizzare per attività illegali.
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
---
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
## Indice
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
- [Requisiti](#requisiti)
|
|
|
|
|
- [Installazione Rapida](#installazione-rapida)
|
|
|
|
|
- [Utilizzo](#utilizzo)
|
|
|
|
|
- [Comandi Make](#comandi-make)
|
|
|
|
|
- [Troubleshooting](#troubleshooting)
|
|
|
|
|
- [Note Tecniche](#note-tecniche)
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
---
|
2026-01-23 08:48:08 +01:00
|
|
|
|
|
|
|
|
## Requisiti
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Sistema Operativo
|
|
|
|
|
- **Linux**: Ubuntu/Debian (consigliato)
|
|
|
|
|
- **Architettura**: x86_64 o ARM64
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Hardware Minimo
|
|
|
|
|
- **CPU**: Multicore (consigliato 8+ core)
|
|
|
|
|
- **RAM**: 2GB minimo, 4GB+ consigliato
|
|
|
|
|
- **Disco**: 500MB per libreria locale
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Software
|
2026-01-23 08:48:08 +01:00
|
|
|
```bash
|
|
|
|
|
sudo apt-get update
|
2026-01-23 20:05:02 +01:00
|
|
|
sudo apt-get install -y build-essential git autoconf libtool pkg-config libgmp-dev
|
2026-01-23 08:48:08 +01:00
|
|
|
```
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
---
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
## Installazione Rapida
|
2026-01-23 08:48:08 +01:00
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
cd bruteforce
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
# Compila automaticamente (prima volta ~5 minuti)
|
|
|
|
|
make
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
# Esegui
|
|
|
|
|
./p2pk_bruteforce
|
2026-01-23 08:48:08 +01:00
|
|
|
```
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
**Risultato atteso**: ~300K keys/sec
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
> **Nota**: La prima volta `make` compilerà automaticamente libsecp256k1 locale (~5 minuti). Le volte successive sarà istantaneo.
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
---
|
2026-01-23 08:48:08 +01:00
|
|
|
|
|
|
|
|
## Utilizzo
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### 1. Prepara il File Target
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
Crea `target_keys.txt` con le chiavi pubbliche P2PK (una per riga):
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
```txt
|
|
|
|
|
pubkey_hex
|
|
|
|
|
04a1b2c3d4e5f6789... (130 caratteri hex)
|
|
|
|
|
04f9e8d7c6b5a49321...
|
|
|
|
|
...
|
2026-01-23 08:48:08 +01:00
|
|
|
```
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
**Formato**:
|
|
|
|
|
- Chiavi pubbliche **non compresse** (130 caratteri hex)
|
|
|
|
|
- Prefisso `04` (opzionale)
|
|
|
|
|
- Una chiave per riga
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### 2. Esegui il Programma
|
2026-01-23 08:48:08 +01:00
|
|
|
|
|
|
|
|
```bash
|
2026-01-23 20:05:02 +01:00
|
|
|
# File default (target_keys.txt)
|
|
|
|
|
./p2pk_bruteforce
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
# File custom
|
|
|
|
|
./p2pk_bruteforce mie_chiavi.txt
|
|
|
|
|
```
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### 3. Output Esempio
|
2026-01-23 08:48:08 +01:00
|
|
|
|
|
|
|
|
```
|
|
|
|
|
========================================
|
|
|
|
|
Bitcoin P2PK Bruteforce v1.0
|
|
|
|
|
SOLO PER SCOPI EDUCATIVI
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
|
|
[+] Inizializzazione secp256k1...
|
2026-01-23 20:05:02 +01:00
|
|
|
[+] Bloom filter inizializzato: 64 MB
|
2026-01-23 08:48:08 +01:00
|
|
|
[+] Caricamento chiavi target da target_keys.txt...
|
2026-01-23 20:05:02 +01:00
|
|
|
[+] Caricate 2164 chiavi pubbliche target
|
|
|
|
|
[+] CPU rilevata: 11 thread disponibili
|
|
|
|
|
[+] Partizionamento spazio chiavi in 11 regioni
|
|
|
|
|
[+] Avvio 11 thread worker...
|
|
|
|
|
|
|
|
|
|
[+] Thread 0 avviato su core 0
|
|
|
|
|
Privkey iniziale: 0000000000000000a3f2b1c4d5e6f7a8b9c0d1e2f3a4b5c6d7e8f9a0b1c2d3e4
|
|
|
|
|
[+] Thread 1 avviato su core 1
|
|
|
|
|
Privkey iniziale: 1745d1741745d174f1e2d3c4b5a69788c9d0e1f2a3b4c5d6e7f8a9b0c1d2e3f4
|
2026-01-23 08:48:08 +01:00
|
|
|
...
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
[INFO] Tentativi: 3.30M | Velocità: 300.00K keys/sec | Tempo: 11s
|
|
|
|
|
[INFO] Tentativi: 6.60M | Velocità: 300.00K keys/sec | Tempo: 22s
|
2026-01-23 08:48:08 +01:00
|
|
|
```
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### 4. Chiave Trovata (se succede)
|
2026-01-23 08:48:08 +01:00
|
|
|
|
|
|
|
|
```
|
|
|
|
|
========================================
|
|
|
|
|
🎯 CHIAVE TROVATA! 🎯
|
|
|
|
|
========================================
|
2026-01-23 20:05:02 +01:00
|
|
|
Private Key: a1b2c3d4e5f6...
|
|
|
|
|
Public Key: 04f9e8d7c6b5a4...
|
2026-01-23 08:48:08 +01:00
|
|
|
========================================
|
|
|
|
|
```
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
**Salvata in**: `found_keys.txt`
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
---
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
## Comandi Make
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
```bash
|
|
|
|
|
make # Compila (setup automatico prima volta)
|
|
|
|
|
make clean # Rimuove eseguibili
|
|
|
|
|
make clean-all # Pulizia completa (include secp256k1)
|
|
|
|
|
make help # Mostra tutti i comandi
|
2026-01-23 08:48:08 +01:00
|
|
|
```
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Workflow Consigliato
|
2026-01-23 08:48:08 +01:00
|
|
|
|
|
|
|
|
```bash
|
2026-01-23 20:05:02 +01:00
|
|
|
# Prima compilazione
|
|
|
|
|
make
|
|
|
|
|
|
|
|
|
|
# Modifiche successive al codice
|
2026-01-23 08:48:08 +01:00
|
|
|
make clean
|
|
|
|
|
make
|
|
|
|
|
```
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
---
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
## Troubleshooting
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Errore: Directory secp256k1 non trovata
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
```bash
|
|
|
|
|
make clean-all
|
|
|
|
|
make
|
2026-01-23 08:48:08 +01:00
|
|
|
```
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Velocità Bassa (<250K keys/sec)
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
```bash
|
|
|
|
|
# 1. Verifica libreria usata
|
|
|
|
|
ldd ./p2pk_bruteforce | grep secp256k1
|
|
|
|
|
# Deve mostrare: ./secp256k1/lib/libsecp256k1.so
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
# 2. Verifica carico CPU
|
|
|
|
|
htop # Ogni core dovrebbe essere al 100%
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
# 3. Verifica frequency scaling
|
|
|
|
|
lscpu | grep MHz
|
|
|
|
|
# Se bassa, disabilita power saving
|
|
|
|
|
```
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Errori di Compilazione
|
2026-01-23 08:48:08 +01:00
|
|
|
|
|
|
|
|
```bash
|
2026-01-23 20:05:02 +01:00
|
|
|
# Reinstalla dipendenze
|
|
|
|
|
sudo apt-get install -y build-essential git autoconf libtool pkg-config libgmp-dev
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
# Pulizia completa e ricompilazione
|
|
|
|
|
make clean-all
|
|
|
|
|
make
|
2026-01-23 08:48:08 +01:00
|
|
|
```
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Il Programma non Trova Nulla
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
**Questo è normale!** La probabilità di trovare una chiave è praticamente zero.
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
**Test funzionamento**:
|
|
|
|
|
1. Genera una chiave privata nota
|
|
|
|
|
2. Calcola la pubkey con Bitcoin Core
|
|
|
|
|
3. Aggiungi a `target_keys.txt`
|
|
|
|
|
4. Modifica codice per partire da quella chiave
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
---
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
## Note Tecniche
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Probabilità di Successo
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
**Spazio chiavi**: 2^256 ≈ 10^77
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
Con 300K keys/sec:
|
|
|
|
|
- **1 ora**: ~1 miliardo (10^9) chiavi
|
|
|
|
|
- **1 anno**: ~9.5 trilioni (10^15) chiavi
|
|
|
|
|
- **Universo**: Servirebbe **10^60 anni** per tutto lo spazio
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
**Conclusione**: Statisticamente impossibile trovare una chiave casuale.
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Partizionamento Spazio Chiavi
|
|
|
|
|
|
|
|
|
|
Ogni thread riceve un chunk univoco:
|
2026-01-23 08:48:08 +01:00
|
|
|
```
|
2026-01-23 20:05:02 +01:00
|
|
|
Thread 0: 0x0000000000000000... → 0x1745d1741745d174...
|
|
|
|
|
Thread 1: 0x1745d1741745d174... → 0x2e8ba2e82e8ba2e8...
|
|
|
|
|
...
|
2026-01-23 08:48:08 +01:00
|
|
|
```
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
All'interno del chunk:
|
|
|
|
|
1. Inizia con chiave casuale
|
|
|
|
|
2. Incrementa sequenzialmente +1
|
|
|
|
|
3. **Zero sovrapposizione** garantita
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Bloom Filter
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
- **Dimensione**: 64 MB (2^26 bits)
|
|
|
|
|
- **Hash functions**: 3 indipendenti
|
|
|
|
|
- **False positive**: ~0.01%
|
|
|
|
|
- **Speedup**: ~5-10%
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### Algoritmo Incremento
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
```cpp
|
|
|
|
|
// 4x più veloce di byte-per-byte
|
|
|
|
|
uint64_t* p64 = (uint64_t*)privkey;
|
|
|
|
|
if (++p64[3]) return; // 99.99% dei casi termina qui
|
|
|
|
|
if (++p64[2]) return;
|
|
|
|
|
if (++p64[1]) return;
|
|
|
|
|
++p64[0];
|
|
|
|
|
```
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
### libsecp256k1 Ottimizzata
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
Flags di compilazione:
|
|
|
|
|
```bash
|
|
|
|
|
-O3 # Ottimizzazione massima
|
|
|
|
|
-march=native # Istruzioni CPU native (AVX2, etc)
|
|
|
|
|
-mtune=native # Tuning per CPU specifica
|
|
|
|
|
-flto # Link-Time Optimization
|
|
|
|
|
-fomit-frame-pointer # Rimuove frame pointer
|
|
|
|
|
-funroll-loops # Loop unrolling aggressivo
|
|
|
|
|
```
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
Window size: **15** (standard ottimale per ECC)
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
---
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
## Contributori
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
Sviluppato con **Claude Code** (Anthropic)
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
## Riferimenti
|
2026-01-23 08:48:08 +01:00
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
- [Bitcoin Core secp256k1](https://github.com/bitcoin-core/secp256k1)
|
|
|
|
|
- [SECP256k1 Specification](https://en.bitcoin.it/wiki/Secp256k1)
|
|
|
|
|
- [Bloom Filters](https://en.wikipedia.org/wiki/Bloom_filter)
|
|
|
|
|
- [Elliptic Curve Cryptography](https://en.wikipedia.org/wiki/Elliptic-curve_cryptography)
|
2026-01-23 08:48:08 +01:00
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
2026-01-23 20:05:02 +01:00
|
|
|
**⚠️ Ricorda**: Questo progetto dimostra l'impossibilità pratica del bruteforce su Bitcoin. **La crittografia funziona.**
|