账户在以太坊中发挥着中心作用。共有两种账户类型:外部账户(EOAs)和合约账户。我们这里重点讲一下外部账户,以下会简称为账户。合约账户简称为合约, 在合约章节具体讨论。把外部账户和合约账户都归入到帐户的一般概念是合理的,因为这些实体都是所谓的状态对象。这些实体都有状态:账户有余额,合约既有余额也有合约储存。所有账户的状态正是以太坊网络的状态,以太坊网络和每个区块一起更新,网络需要达成关于以太坊的共识。对于用户通过交易和以太坊区块链互动来说,账户是必不可少的。
如果我们把以太坊限制为只有外部账户,只允许外部账户之间进行交易,我们就会进入到“代币”系统,“代币”系统不如比特币本身有力,只能用于转移以太币。
账户代表着外部代理人(例如人物角色,挖矿节点 ,或是自动代理人)的身份。账户运用公钥加密图像来签署交易以便以太坊虚拟机可以安全地验证交易发送者身份。
每个账户都由一对钥匙定义,一个私钥和一个公钥。 账户以地址为索引,地址由公钥衍生而来,取公钥的最后 20个字节。每对私钥 /地址都编码在一个钥匙文件里。钥匙文件是JSON文本文件,可以用任何文本编辑器打开和浏览。钥匙文件的关键部分,账户私钥,通常用你创建帐户时设置的密码进行加密。钥匙文件可以在以太坊节点数据目录的keystore子目录下找到。确保经常给钥匙文件备份!查看备份和恢复账号章节了解更多。创建钥匙和创建帐户是一样的。
当然新账户不包含任何以太币。但它将会是你的,你大可放心,没有你的钥匙和密码,没有人能进入。
转换整个目录或任何以太坊节点之间的个人钥匙文件都是安全的。
警告:请注意万一你从一个不同的节点向另一个节点添加钥匙文件, 账户的顺序可能发生改变。确保不要回复或改变手稿中的索引或代码片段。
警告:记住密码并“备份钥匙文件<backup-and-restore-accounts>”。为了从账号发送交易,包括发送以太币,你必须同时有钥匙文件和密码。确保钥匙文件有个备份并牢记密码,尽可能安全地存储它们。这里没有逃亡路径,如果钥匙文件丢失或忘记密码,就会丢失所有的以太币。没有密码不可能进入账号,也没有忘记密码选项。所以一定不要忘记密码。
一旦安装了geth客户端,创建账号就只是在终端执行 geth account new指令的问题了。
注意不必运行geth客户端或者和区块链同步来使用geth account指令。
1 |
|
1 2 3 4 |
|
对于非交互式使用,你可以提供纯文本密码文件作为—password标志的变元。文件中的数据包含密码的原始字节,后面可选择单独跟着新的一行。
1 |
|
警告:用—password标志只是为了测试或在信任的环境中自动操作。不建议将密码保存在文件中或以任何其他方式暴露。如果你用密码文件来使用—password标志,要确保文件只对你自己可阅读和列表。你可以在 Mac/Linux系统中通过以下指令实现:
1 2 3 4 |
|
要列出目前在你的keystore文件夹中的钥匙文件的所有账号,使用 geth account指令的list子指令:
1 |
|
1 2 3 |
|
钥匙文件的文件名格式为UTC—<created_at UTC ISO8601>–
。账号列出时是按字母顺序排列,但是由于时间戳格式,实际上它是按创建顺序排列。
为了用geth创建新账号,我们必须先在控制台模式开启geth(或者可以用 geth attach将控制台依附在已经运行着的事例上):
1 2 3 4 5 |
|
控制台使你能够通过发出指令与本地节点互相作用。比如,试一下这个列出账号的指令:
1 2 3 4 5 |
|
这就表明你没有账号。你也可以从控制台创建一个账号:
1 2 3 4 |
|
注意:记得用一个安全性强、随机生成的密码。
我们刚刚创建了第一个账号。如果我们再次试着列出账号,就可以看到新创建的账号了。
1 2 |
|
对于相反的命令行,现在有一个基于GUI的选项可以用来创建账号:“官方”Mist以太坊钱包。 Mist以太坊钱包,和它的父项目Mist, 是在以太坊基金会的赞助下开发,因此是“官方”地位。钱包应用有Linux, Mac OS X和Windows可用的版本。
警告:Mist钱包是试用软件,使用需风险自担。
用GUI Mist以太坊钱包创建账号再容易不过了。事实上,第一个账号在应用安装期间就创建出来了。