以太坊连载(11):以太坊账户管理

2016-08-30 09:58 来源:巴比特资讯 阅读:8581
账户在以太坊中发挥着中心作用。共有两种账户类型:外部账户(EOAs)和合约账户。我们这里重点讲一下外部账户,以下会简称为账户。

账户

账户在以太坊中发挥着中心作用。共有两种账户类型:外部账户(EOAs)和合约账户。我们这里重点讲一下外部账户,以下会简称为账户。合约账户简称 为合约, 在合约章节具体讨论。把外部账户和合约账户都归入到帐户的一般概念是合理的,因为这些实体都是所谓的状态对象。这些实体都有状态:账户有余额,合约既有余 额也有合约储存。所有账户的状态正是以太坊网络的状态,以太坊网络和每个区块一起更新,网络需要达成关于以太坊的共识。对于用户通过交易和以太坊区块链互 动来说,账户是必不可少的。

如果我们把以太坊限制为只有外部账户,只允许外部账户之间进行交易,我们就会进入到“代币”系统,“代币”系统不如比特币本身有力,只能用于转移以太币。

账户代表着外部代理人(例如人物角色,挖矿节点 ,或是自动代理人)的身份。账户运用公钥加密图像来签署交易以便以太坊虚拟机可以安全地验证交易发送者身份。

以太坊

钥匙文件

每个账户都由一对钥匙定义,一个私钥和一个公钥。 账户以地址为索引,地址由公钥衍生而来,取公钥的最后 20个字节。每对私钥 /地址都编码在一个钥匙文件里。钥匙文件是JSON文本文件,可以用任何文本编辑器打开和浏览。钥匙文件的关键部分,账户私钥,通常用你创建帐户时设置的 密码进行加密。钥匙文件可以在以太坊节点数据目录的keystore子目录下找到。确保经常给钥匙文件备份!查看备份和恢复账号章节了解更多。创建钥匙和 创建帐户是一样的。

  1. 不必告诉任何人你的操作。

  2. 不必和区块链同步。

  3. 不必运行客户端。

  4. 甚至不必连接到网络。

当然新账户不包含任何以太币。但它将会是你的,你大可放心,没有你的钥匙和密码,没有人能进入。

转换整个目录或任何以太坊节点之间的个人钥匙文件都是安全的。

警告:请注意万一你从一个不同的节点向另一个节点添加钥匙文件, 账户的顺序可能发生改变。确保不要回复或改变手稿中的索引或代码片段。

创建账号

警告:记住密码并“备份钥匙文件<backup-and-restore-accounts>”。为了从账号发送交易,包括发送以太 币,你必须同时有钥匙文件和密码。确保钥匙文件有个备份并牢记密码,尽可能安全地存储它们。这里没有逃亡路径,如果钥匙文件丢失或忘记密码,就会丢失所有 的以太币。没有密码不可能进入账号,也没有忘记密码选项。所以一定不要忘记密码。

使用geth account new

一旦安装了geth客户端,创建账号就只是在终端执行 geth account new指令的问题了。

注意不必运行geth客户端或者和区块链同步来使用geth account指令。

1
$ geth account new
1
2
3
4
Your new account is locked with a password. Please give a password. Do not forget this password.
Passphrase:
Repeat Passphrase:
Address: {168bc315a2ee09042d83d7c5811b533620531f67}

对于非交互式使用,你可以提供纯文本密码文件作为—password标志的变元。文件中的数据包含密码的原始字节,后面可选择单独跟着新的一行。

1
$ geth --password /path/to/password account new

警告:用—password标志只是为了测试或在信任的环境中自动操作。不建议将密码保存在文件中或以任何其他方式暴露。如果你用密码文件来使用—password标志,要确保文件只对你自己可阅读和列表。你可以在 Mac/Linux系统中通过以下指令实现:

1
2
3
4
touch /path/to/password
chmod 600 /path/to/password
cat > /path/to/password
>I type my pass

要列出目前在你的keystore文件夹中的钥匙文件的所有账号,使用 geth account指令的list子指令:

1
$ geth account list
1
2
3
account #0: {a94f5374fce5edbc8e2a8697c15331677e6ebf0b}
account #1: {c385233b188811c9f355d4caec14df86d6248235}
account #2: {7f444580bfef4b9bc7e14eb7fb2a029336b07c9d}

钥匙文件的文件名格式为UTC—<created_at UTC ISO8601>–

。账号列出时是按字母顺序排列,但是由于时间戳格式,实际上它是按创建顺序排列。

使用geth控制台

为了用geth创建新账号,我们必须先在控制台模式开启geth(或者可以用 geth attach将控制台依附在已经运行着的事例上):

1
2
3
4
5
> geth console 2>> file_to_log_output
instance: Geth/v1.4.0-unstable/linux/go1.5.1
coinbase: coinbase: [object Object]
at block: 865174 (Mon, 18 Jan 2016 02:58:53 GMT)
datadir: /home/USERNAME/.ethereum

控制台使你能够通过发出指令与本地节点互相作用。比如,试一下这个列出账号的指令:

1
2
3
4
5
> eth.accounts
{
code: -32000,
message: "no keys in store"
}

这就表明你没有账号。你也可以从控制台创建一个账号:

1
2
3
4
> personal.newAccount()
Passphrase:
Repeat passphrase:
"0xb2f69ddf70297958e582a0cc98bce43294f1007d"

注意:记得用一个安全性强、随机生成的密码。

我们刚刚创建了第一个账号。如果我们再次试着列出账号,就可以看到新创建的账号了。

1
2
> eth.accounts
["0xb2f69ddf70297958e582a0cc98bce43294f1007d"]

使用 Mist 以太坊钱包

对于相反的命令行,现在有一个基于GUI的选项可以用来创建账号:“官方”Mist以太坊钱包。 Mist以太坊钱包,和它的父项目Mist, 是在以太坊基金会的赞助下开发,因此是“官方”地位。钱包应用有Linux, Mac OS X和Windows可用的版本。

警告:Mist钱包是试用软件,使用需风险自担。

用GUI Mist以太坊钱包创建账号再容易不过了。事实上,第一个账号在应用安装期间就创建出来了。

  1. 根据你的操作程序下载钱包应用最新版本。由于你实际上会运行一个完整的geth节点,打开钱包应用就会开始同步复制你电脑上的整个以太坊区块链。

  2. 解锁下载的文件夹,运行以太坊钱包可执行文件。

  3. 等待区块链完全同步,按照屏幕上的说明操作,第一个账号就创建出来了。

  4. 第一次登录Mist 以太坊钱包,你会看到自己在安装过程中创建的账号。它会被默认命名为主账号(以太库)

  5. 再另外创建账号很容易;只需点击应用主界面上的添加账号,输入所需的密码即可。

注意: Mist钱包仍在开发中,以上列出的具体步骤可能会随着更新有所变更。原文:http://wangxiaoming.com/blog/2016/06/22/e11/

下一篇文章我们将会介绍《以太坊连载(12):创建安全多签名钱包及高级设置》

感谢朝夕团队Azure, Bob参与《Ethereum Homestead Documentation》的翻译和校验。


声明:此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。本网站所提供的信息,只供参考之用。

点击阅读全文