You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
58 lines
1.6 KiB
58 lines
1.6 KiB
10 years ago
|
# Private Key
|
||
|
|
||
|
Represents a bitcoin private key and is needed to be able to spend bitcoin and sign transactions. See the official [Bitcoin Wiki](https://en.bitcoin.it/wiki/Private_key) for more information about private keys. A PrivateKey in Bitcore is an immutable object that has methods to import and export into a variety of formats including [Wallet Import Format](https://en.bitcoin.it/wiki/Wallet_import_format).
|
||
|
|
||
|
## Instantiate a Private Key
|
||
|
|
||
|
Here is how to create a new private key. It will generate a new random number using `window.crypto` or the Node.js 'crypto' library.
|
||
|
|
||
|
```javascript
|
||
|
|
||
|
var PrivateKey = require('bitcore/lib/privatekey');
|
||
|
var privateKey = new PrivateKey();
|
||
|
|
||
|
```
|
||
|
|
||
|
To export and import a private key, you can do the following:
|
||
|
|
||
|
```javascript
|
||
|
|
||
|
// encode into wallet export format
|
||
|
var exported = privateKey.toWIF();
|
||
|
|
||
|
// instantiate from the exported (and saved) private key
|
||
|
var imported = PrivateKey.fromWIF(exported);
|
||
|
|
||
|
```
|
||
|
|
||
|
Note: The WIF (Wallet Import Format) includes information about the network and if the associated public key is compressed or uncompressed (thus the same bitcoin address will be generated by using this format).
|
||
|
|
||
|
To generate an Address or PublicKey from a PrivateKey:
|
||
|
|
||
|
```javascript
|
||
|
|
||
|
var address = privateKey.toAddress();
|
||
|
var publicKey = privateKey.toPublicKey();
|
||
|
|
||
|
```
|
||
|
|
||
|
## Validating a Private Key
|
||
|
|
||
|
The code to do these validations looks like this:
|
||
|
|
||
|
```javascript
|
||
|
|
||
|
// validate an address
|
||
|
if (PrivateKey.isValid(input){
|
||
|
...
|
||
|
}
|
||
|
|
||
|
// get the specific validation error that can occurred
|
||
|
var error = PrivateKey.getValidationError(input, Networks.livenet);
|
||
|
if (error) {
|
||
|
// handle the error
|
||
|
}
|
||
|
}
|
||
|
|
||
|
```
|