Generate Ethereum Wallet from Private Key. Many times users have Private Key and they want to generate Ethereum compatible password protected wallet from that key. Here is a small utility program for Ethereum Blockchain in NodeJS that would help user to generate Ethereum compatible password protected wallet starting just with Private Key. If you are using Node.js, you can use the package called “ethereumjs-wallet” to generate Ethereum private keys and addresses. This is an official package provided and maintained by the Ethereum JavaScript community. To generate Ethereum addresses, follow these steps: Step 1: Create Node project To create a new Node project, create a new folder and …. Wallet software may use a BIP 32 seed to generate many private keys and corresponding public keys from a single secret value. This is called a hierarchical deterministic wallet, or HD wallet for short. The seed value, or master extended key, consists of a 256-bit private key and a 256-bit chain code, for 512 bits in total.
∟Managing Ethereum Account
∟Ethereum Account Keystore File
This section describes the keystore file that contains the private key of an Ethereum account.
An Ethereum account keystore file is JSON file, that stores the private key of an Ethereum account.
We can use the importRawKey() function on the 'geth' JavaScript console to create keystore file from a private key:
Then view the keystore file content with the Windows 'type' command:
Note that the above keystore file has been reformatted.
As you can see, the private key has been encrypted by the password and stored to the 'ciphertext' property. The public key is stored as the 'addres' property.
Please do not send any Ether to this public key, since the private key is published, anyone can use it to spend the Ether fund associated to this public key.
Table of Contents
About This Book
Introduction of Ethereum
Ethereum Blockchain
Ethereum Mist Wallet
geth - Go Ethereum
Testnet - Ropsten network
Private Ethereum Network
64-Bit 'geth' for Private Ethereum Network
Private Network with Custom Genesis Block
Transferring Funds between Ether Accounts
MetaMask - Browser Based Ethereum Wallet
►Managing Ethereum Account
What Is Ethereum Account
Generate New Ethereum Accounts
Ethereum Public Key and Private Key Example
►Ethereum Account Keystore File
'geth' Commands for Ethereum Accounts
ethereumfaucet.info - Mining Ether with Browser
References
Full Version in PDF/EPUB
Accounts¶
Accounts play a central role in Ethereum. There are two types of accounts: externally owned accounts (EOAs) and contract accounts. Here we focus on externally owned accounts, which will be referred to simply as accounts. Contract accounts will be referred to as contracts and are discussed in detail in Contracts. This generic notion of account subsuming both externally owned accounts and contracts is justified in that these entities are so called state objects. These entities have a state: accounts have balance and contracts have both balance and contract storage. The state of all accounts is the state of the Ethereum network which is updated with every block and which the network really needs to reach a consensus about.Accounts are essential for users to interact with the Ethereum blockchain via transactions.
If we restrict Ethereum to only externally owned accounts and allow only transactions between them, we arrive at an “altcoin” system that is less powerful than bitcoin itself and can only be used to transfer ether.
Accounts represent identities of external agents (e.g., human personas, mining nodes or automated agents). Accounts use public key cryptography to sign transaction so that the EVM can securely validate the identity of a transaction sender.
Keyfiles¶
Every account is defined by a pair of keys, a private key and public key. Accounts are indexed by their address which is derived from the public key by taking the last 20 bytes. Every private key/address pair is encoded in a keyfile. Keyfiles are JSON text files which you can open and view in any text editor. The critical component of the keyfile, your account’s private key, is always encrypted, and it is encrypted with the password you enter when you create the account. Keyfiles are found in the keystore
subdirectory of your Ethereum node’s data directory. Make sure you backup your keyfiles regularly! See the section Backup and restore accounts for more information.
Creating a key is tantamount to creating an account.
- You don’t need to tell anybody else you’re doing it
- You don’t need to synchronize with the blockchain
- You don’t need to run a client
- You don’t even need to be connected to the internet
Of course your new account will not contain any Ether. But it’ll be yours and you can be certain that without your key and your password, nobody else can ever access it.
It is safe to transfer the entire directory or any individual keyfile between Ethereum nodes.
Warning
Note that in case you are adding keyfiles to your node from a different node, the order of accounts may change. So make sure you do not rely or change the index in your scripts or code snippets.
Creating an account¶
Warning
Remember your passwords and :ref:`backup your keyfiles <backup-and-restore-accounts>`. In order to send transactions from an account, including sending ether, you must have BOTH the keyfile and the password. Be absolutely sure to have a copy of your keyfile AND remember the password for that keyfile, and store them both as securely as possible. There are no escape routes here; lose the keyfile or forget your password and all your ether is gone. It is NOT possible to access your account without a password and there is no forgot my password option here. Do not forget it.
Using gethaccountnew
¶
Once you have the geth client installed, creating an account is merely a case of executing the gethaccountnew
command in a terminal.
Note that you do not have to run the geth client or sync up with the blockchain to use the gethaccount
command.
For non-interactive use you supply a plaintext password file as argument to the --password
flag. The data in the file consists of the raw bytes of the password optionally followed by a single newline.
Warning
Using the --password
flag is meant to be used only for testing or automation in trusted environments. It is a bad idea to save your password to file or expose it in any other way. If you do use the --password
flag with a password file, make sure the file is not readable or even listable for anyone but you. You can achieve this in Mac/Linux systems with:
To list all the accounts with keyfiles currently in you’re keystore
folder use the list
subcommand of the gethaccount
command:
The filenames of keyfiles has the format UTC--<created_atUTCISO8601>-<addresshex>
. The order of accounts when listing, is lexicographic, but as a consequence of the timestamp format, it is actually order of creation.
Using geth console¶
In order to create a new account using geth, we must first start geth in console mode (or you can use gethattach
to attach a console to an already running instance):
The console allows you to interact with your local node by issuing commands. For example, try the command to list your accounts:
This shows that you have no accounts. You can also create an account from the console:
Note
Remember to use a strong and randomly generated password.
We just created our first account. If we try to list our accounts again we can see our new account:
Using Mist Ethereum wallet¶
For the command line averse, there is now a GUI-based option for creating accounts: The “official” Mist Ethereum wallet. The Mist Ethereum wallet, and its parent Mist project, are being developed under the auspices of the Ethereum Foundation, hence the “official” status. Versions of the wallet app are available for Linux, Mac OS X, and Windows.
Warning
The Mist wallet is beta software. Please beware and use it at your own risk.
Creating an account using the GUI Mist Ethereum wallet couldn’t be easier. In fact, your first account is created during the installation of the app.
- Download the latest version of the wallet app for your operating system. Opening the Wallet App will kick off syncing a full copy of the Ethereum blockchain on your computer, since you will in effect be running a full geth node.
- Unzip the downloaded folder and run the Ethereum-Wallet executable file.
- Wait for the blockchain to fully sync, then follow the instructions on the screen and your first account will be created.
- When you launch the Mist Ethereum wallet for the first time, you will see the account you created during the installation process. By default it will be named MAIN ACCOUNT (ETHERBASE).
- Creating additional accounts is easy; just click on ADD ACCOUNT in the app’s main screen and enter the required password.
Note
The Mist wallet is still in active development, so details of the steps outlined above may change with upgrades.
Creating a Multi-Signature Wallet in Mist¶
The Mist Ethereum wallet has an option to secure your wallet balance with a multisig wallet. The advantage of using a multisig wallet is that it requires authorization from more than one account to withdrawal larger amounts from your balance. Before you can create a multisig wallet, you’ll need to create more than one account.
Generate Ethereum Private Key Javascript Online
It’s very easy to create account files in Mist. In the ‘Accounts’ section click ‘Add Account’. Pick a strong yet easy-to-remember password (remember there is no password recovery option), confirm it, and your account is created. Create at least 2 accounts. Secondary accounts can be created on separate computers running Mist if you prefer (and theoretically make your multisig more secure doing it this way). You only need the public keys (your deposit addresses) of your secondary accounts when creating the multisig wallet (copy/paste them, do not ever type them by hand). Your primary account will be needed to create the multisig wallet contract, so it must be on the computer you are creating the multisig wallet on.
Now that you have your accounts setup, be safe and back them up (if your computer crashes, you will lose your balance if you do not have a backup). Click ‘Backup’ in the top menu. Choose the ‘keystore’ folder, opposite-click on it / choose ‘copy’ (do NOT choose ‘cut’, that would be very bad). Navigate to your desktop, opposite-click in a blank area and choose ‘paste’. You may want to rename this new copy of the ‘keystore’ folder to something like ‘Ethereum-keystore-backup-year-month-day’ so you have quick recognition of it later. At this point you can then add the folder contents to a zip / rar file (and even password-protect the archive with another strong yet easy-to-remember password if backing up online), copy it to a USB Drive, burn it to a CD / DVD, or upload it to online storage (Dropbox / Google Drive / etc).
You now should add approximately no less than 0.02 ETH to your primary account (the account you will initiate creation of a multisig wallet with). This is required for the transaction fee when you create the multisig wallet contract. An additional 1 ETH (or more) is also needed, because Mist currently requires this to assure wallet contract transactions have enough ‘gas’ to execute properly...so no less than about 1.02 ETH total for starters.
You will be entering the full addresses of all the accounts you are attaching to this multisig wallet, when you create it. I recommend copying / pasting each address into a plain text editor (notepad / kedit / etc), after going to each account’s details page in Mist, and choosing ‘copy address’ from the right-side column of buttons. Never type an address by hand, or you run a very high risk of typos and could lose your balance sending transactions to the wrong address.
We are now ready to create the multisig wallet. Under ‘Wallet Contracts’, select ‘Add Wallet Contract’. Give it a name, select the primary account owner, and choose ‘Multisignature Wallet Contract’. You will see something like this appear:
“This is a joint account controlled by X owners. You can send up to X ether per day. Any transaction over that daily limit requires the confirmation of X owners.”
Set whatever amount of owners (accounts) you are attaching to this multisig wallet, whatever you want for a daily withdrawal limit (that only requires one account to withdrawal that amount), and how many owners (accounts) are required to approve any withdrawal amount over the daily limit.
Now add the addresses of the accounts that you copied / pasted into your text editor earlier, confirm all your settings are correct, and click ‘Create’ at the bottom. You will then need to enter your password to send the transaction. In the ‘Wallet Contracts’ section it should show your new wallet, and say ‘creating’.
When wallet creation is complete, you should see your contract address on the screen. Select the entire address, copy / paste it into a new text file in your text editor, and save the text file to your desktop as ‘Ethereum-Wallet-Address.txt’, or whatever you want to name it.
Now all you need to do is backup the ‘Ethereum-Wallet-Address.txt’ file the same way you backed up your account files, and then you are ready to load your new multisig wallet with ETH using this address.
If you are restoring from backup, simply copy the files inside the ‘Ethereum-keystore-backup’ folder over into the ‘keystore’ folder mentioned in the first section of this walkthrough. FYI, you may need to create the ‘keystore’ folder if it’s a brand new install of Mist on a machine it was never installed on before (the first time you create an account is when this folder is created). As for restoring a multisig wallet, instead of choosing ‘Multisignature Wallet Contract’ like we did before when creating it, we merely choose ‘Import Wallet’ instead.
Troubleshooting:
- Mist won’t sync. One solution that works well is syncing your PC hardware clock with an NTP server so the time is exactly correct...then reboot.
- Mist starts after syncing, but is a blank white screen. Chances are you are running the “xorg” video drivers on a Linux-based OS (Ubuntu, Linux Mint, etc). Try installing the manufacturer’s video driver instead.
- “Wrong password” notice. This seems to be a false notice on occasion on current Mist versions. Restart Mist and the problem should go away (if you indeed entered the correct password).
Using Eth¶
Every options related to key management available using geth can be used the same way in eth.
Below are “account” related options:
Below are “wallet” related option:
Note
the ‘account import’ option can only be used to import generic key file. the ‘wallet import’ option can only be used to import a presale wallet.
It is also possible to access keys management from the integrated console (using the built-in console or geth attach):
Using EthKey (deprecated)¶
Ethkey is a CLI tool of the C++ implementation that allows you to interact with the Ethereum wallet. With it you can list, inspect, create, delete and modify keys and inspect, create and sign transactions.
We will assume you have not yet run a client such as eth or anything in the Aleth series of clients. If you have, you can skip this section.To create a wallet, run ethkey
with the createwallet
command:
Please enter a MASTER passphrase to protect your key store (make it strong!):You’ll be asked for a “master” passphrase. This protects your privacy and acts as a default password for any keys. You’ll need to confirm it by entering the same text again.
Note
Use a strong randomly generated password.
We can list the keys within the wallet simply by using the list command:
Generate Ethereum Private Key Javascript Free
We haven’t yet created any keys, and it’s telling us so! Let’s create one.
To create a key, we use the new
command. To use it we must pass a name - this is the name we’ll give to this account in the wallet. Let’s call it “test”:
Enter a passphrase with which to secure this account (or nothing to use the master passphrase).It will prompt you to enter a passphrase to protect this key. If you just press enter, it’ll use the default “master” passphrase. Typically this means you won’t need to enter the passphrase for the key when you want to use the account (since it remembers the master passphrase). In general, you should try to use a different passphrase for each key since it prevents one compromised passphrase from giving access to other accounts. However, out of convenience you might decide that for low-security accounts to use the same passphrase.
Here, let’s give it the incredibly imaginative passphrase of 123. (Never ever use simple passwords like this for anything else than ephemeral test accounts).Once you enter a passphrase, it’ll ask you to confirm it by entering again. Enter 123 a second time.Because you gave it its own passphrase, it’ll also ask you to provide a hint for this password which will be displayed to you whenever it asks you to enter it. The hint is stored in the wallet and is itself protected by the master passphrase. Enter the truly awful hint of 321 backwards.
All normal (aka direct) ICAP addresses begin with XE so you should be able to recognize them easily. Notice also that the key has another identifier after Created key. This is known as the UUID. This is a unique identifier for the key that has absolutely nothing to do with the account itself. Knowing it does nothing to help an attacker discover who you are on the network. It also happens to be the filename for the key, which you can find in either ~/.web3/keys (Mac or Linux) or $HOME/AppData/Web3/keys (Windows).Now let’s make sure it worked properly by listing the keys in the wallet:
It reports one key on each line (for a total of one key here). In this case our key is stored in a file 055dde... and has an ICAP address beginning XE472EVK.... Not especially easy things to remember so rather helpful that it has its proper name, test, too.
Importing your presale wallet¶
Using Mist Ethereum wallet¶
Importing your presale wallet using the GUI Mist Ethereum wallet is very easy. In fact, you will be asked if you want to import your presale wallet during the installation of the app.
Warning
Mist wallet is beta software. Beware and use it at your own risk.
Instructions for installing the Mist Ethereum wallet are given in the section Creating an account: Using Mist Ethereum wallet.
Simply drag-and-drop your .json
presale wallet file into the designated area and enter your password to import your presale account.
If you choose not to import your presale wallet during installation of the app, you can import it at any time by selecting the Accounts
menu in the app’s menu bar and then selecting ImportPre-saleAccounts
.
Note
The Mist wallet is still in active development, so details of the steps outlined above may change with upgrades.
Using geth¶
If you have a standalone installation of geth, importing your presale wallet is accomplished by executing the following command in a terminal:
You will be prompted to enter your password.
Updating an account¶
You are able to upgrade your keyfile to the latest keyfile format and/or upgrade your keyfile password.
Using geth¶
You can update an existing account on the command line with the update
subcommand with the account address or index as parameter. Remember that the account index reflects the order of creation (lexicographic order of keyfile names containing the creation time).
or
For example:
The account is saved in the newest version in encrypted format, you are prompted for a passphrase to unlock the account and another to save the updated file. This same command can be used to migrate an account of a deprecated format to the newest format or change the password for an account.
For non-interactive use the passphrase can be specified with the --password
flag:
Since only one password can be given, only format update can be performed, changing your password is only possible interactively.
Note
account update has the side effect that the order of your accounts may change. After a successful update, all previous formats/versions of that same key will be removed!
Backup and restore accounts¶
Manual backup/restore¶
You must have an account’s keyfile to be able to send any transaction from that account. Keyfiles are found in the keystore subdirectory of your Ethereum node’s data directory. The default data directory locations are platform specific:
- Windows:
C:Usersusername%appdata%RoamingEthereumkeystore
- Linux:
~/.ethereum/keystore
- Mac:
~/Library/Ethereum/keystore
To backup your keyfiles (accounts), copy either the individual keyfiles within the keystore
subdirectory or copy the entire keystore
folder.
To restore your keyfiles (accounts), copy the keyfiles back into the keystore
subdirectory, where they were originally.
Importing an unencrypted private key¶
Importing an unencrypted private key is supported by geth
This command imports an unencrypted private key from the plain text file <keyfile>
and creates a new account and prints the address.The keyfile is assumed to contain an unencrypted private key as canonical EC raw bytes encoded into hex.The account is saved in encrypted format, you are prompted for a passphrase. You must remember this passphrase to unlock your account in the future.
An example where the data directory is specified. If the --datadir
flag is not used, the new account will be created in the default data directory, i.e., the keyfile will be placed in the keystore
subdirectory of the data directory.
For non-interactive use the passphrase can be specified with the --password
flag:
Note
Generate Ethereum Private Key
Since you can directly copy your encrypted accounts to another Ethereum instance, this import/export mechanism is not needed when you transfer an account between nodes.
Warning
Generate Ethereum Private Key Javascript Code
When you copy keys into an existing node’s keystore
, the order of accounts you are used to may change. Therefore you make sure you either do not rely on the account order or double-check and update the indexes used in your scripts.