This is a web application that allows users to generate random private keys and corresponding public addresses for Bitcoin and Ethereum. Users can also view their balances (for Ethereum, it queries real-time balances using the Ethereum blockchain). The application uses BitcoinJS, Ethers.js, and Elliptic libraries for cryptographic key generation.
-
Bitcoin and Ethereum Key Generation:
- Easily generate random private keys for Bitcoin and Ethereum.
- Bitcoin private keys can be viewed in WIF (Wallet Import Format) or hexadecimal.
- Ethereum private keys are displayed in hexadecimal.
-
Public Key Formats for Bitcoin:
- Supports both P2PKH (Pay-to-PubKey-Hash) and P2WPKH (Pay-to-Witness-PubKey-Hash) formats for Bitcoin public addresses.
-
Balance Check for Ethereum:
- Queries real-time Ethereum balances using the Infura API.
- Displays the balance in ETH for Ethereum addresses.
-
Dynamic UI:
- Toggle between Bitcoin and Ethereum key generation.
- Choose between different public key and private key formats for Bitcoin.
- Next.js - React framework for server-side rendering and static site generation.
- BitcoinJS - JavaScript library for Bitcoin cryptography and transactions.
- Ethers.js - Library for interacting with the Ethereum blockchain.
- Elliptic - Elliptic curve cryptography library (secp256k1 for Bitcoin and Ethereum).
To set up this project locally, follow these steps:
- Clone the repository:
git clone https://github.com/gkfyr/random-pvk-generator.git
- Navigate to the project folder:
cd random-pvk-generator
- Install the dependencies:
npm install
- Set up the .env file with your Infura API endpoint:
NEXT_PUBLIC_INFURA_ENDPOINT=<YOUR_INFURA_ENDPOINT>
Replace <YOUR_INFURA_ENDPOINT> with your Infura Project ID.
- Run the development server:
npm run dev
Open http://localhost:3000 to view the app in the browser.
- Select either Bitcoin or Ethereum using the toggle buttons.
- For Bitcoin, you can choose the type of public key (P2PKH or P2WPKH) and private key format (WIF or Hexadecimal).
- Click the Reload button to generate 8 new keys and addresses.
- If Ethereum is selected, balances for the generated addresses will be fetched automatically.
pages/
- Contains Next.js pages.components/
- Reusable React components.utils/
- Utility functions such as Bitcoin key generation logic..env
- Environment variables for API keys.
This project is licensed under the MIT License. See the LICENSE file for details.
If you have any questions or feedback, feel free to reach out to me at:
- GitHub: https://github.com/gkfyr
- Email: [email protected]