pull down to refresh

Nonce Reuse Attack

- If you prefer reading on the website, check πŸ‘‰ https://bitcoindevs.xyz/decoding/nonce-reuse-attack

Nonce is a random, unique value used in the signing process.
In Schnorr signatures, each signature requires a fresh nonce. Reusing the same nonce is a dangerous mistake that allows an attacker to calculate your private key.
Let's start by breaking down the Schnorr signature equation to see how this happens.
If the nonce k remains the same across different transactions, an attacker can isolate the private key d by comparing two signatures.
Imagine you want to sign two separate transactions but mistakenly use the same nonce for both. Here's how it plays out:

Here’s where things go wrong when the nonce is reused!
Since the only variable difference between S1 and S2 is the hash of the transactions, an attacker can calculate k and subsequently derive your private key d. This exposes your Bitcoin funds to theft.

How to Prevent Nonce Reuse Attacks ?

The solution is straightforward:
Never reuse a nonce!
Never reuse a nonce!
Never reuse a nonce!
Never reuse a nonce!
Never reuse a nonce!
Never reuse a nonce!
Never reuse a nonce!
Never reuse a nonce!
Always ensure that your cryptographic library generates a unique, random nonce for each signature.

6. Calculating the Private Key from Reused Nonces

Check πŸ‘‰ https://bitcoindevs.xyz/decoding/nonce-reuse-attack for the explanation
How would I know that my cryptographic library generates a unique, random nonce for each signature?
reply
When using libsodium-based cryptography, it does the magic under the hood:
The nonce is derived from the sha512 of hashed private key and the message being signed. Optionally, if enabled during compilation, the nonce can be randomized via func _crypto_sign_ed25519_synthetic_r_hv().
reply
In ECDSA, we use RFC6979 to use a deterministic nonce based on the private key and message, this prevents accidental reuse of the nonce value.
It seems these conventions have not been specified in Schnorr. We probably need an RFC or BIP on ensuring deterministic nonces in Schnorr too to ensure that wallet or library implementers do not get this wrong.
Biased nonces can lead to complete private key compromise! https://ecc2017.cs.ru.nl/slides/ecc2017-tibouchi.pdf
reply
deleted by author
reply
deleted by author
Semi related to your post but back in the day there was an attack on Bluetooth (in LE Legacy JW Mode) that had big problems with reusing nonces. It wasn't in signatures like here but I think in key derivation they did something like AES(ox00|π‘Ž|𝑏) with 0x00 being a constant nonce. Quite a hilarious saga.
reply
Sidenote: Nonce literally means number only used once. A lot of people don't know that, even highly respected icons of computer security.
reply