1. 【以太坊易错概念】nonce, 公私钥和地址,BASE64/BASE58,
以太坊里的nonce有两种意思,一个是proof of work nonce,一个是account nonce。
在智能合约里,nonce的值代表的是该合约创建的合约数量。只有当一个合约创建另一个合约的时候才会增加nonce的值。但是当一个合约调用另一个合约中的method时 nonce的值是不变的。
在以太坊中nonce的值可以这样来获取(其实也就是属于一个账户的交易数量):
但是这个方法只能获取交易once的值。目前是没有内置方法来访问contract中的nonce值的
通过椭圆曲线算法生成钥匙对(公钥和私钥),以太坊采用的是secp256k1曲线,
公钥采用uncompressed模式,生成的私钥为长度32字节的16进制字串,公钥为长度64的公钥字串。公钥04开头。
把公钥去掉04,剩下的进行keccak-256的哈希,得到长度64字节的16进制字串,丢掉前面24个,拿后40个,再加上"0x",即为以太坊地址。
整个过程可以归纳为:
2)有些网关或系统只能使用ASCII字符。Base64就是用来将非ASCII字符的数据转换成ASCII字符的一种方法,而且base64特别适合在http,mime协议下快速传输数据。Base64使用【字母azAZ数字09和+/】这64个字符编码。原理是将3个字节转换成4个字节(3 X 8) = 24 = (4 X 6)
当剩下的字符数量不足3个字节时,则应使用0进行填充,相应的,输出字符则使用'='占位,因此编码后输出的文本末尾可能会出现1至2个'='。
1)Base58是用于Bitcoin中使用的一种独特的编码方式,主要用于产生Bitcoin的钱包地址。相比Base64,Base58不使用数字"0",字母大写"O",字母大写"I",和字母小写"l",以及"+"和"/"符号。
Base58Check是一种常用在比特币中的Base58编码格式,增加了错误校验码来检查数据在转录中出现的错误。 校验码长4个字节,添加到需要编码的数据之后。校验码是从需要编码的数据的哈希值中得到的,所以可以用来检测并避免转录和输入中产生的错误。使用 Base58check编码格式时,编码软件会计算原始数据的校验码并和结果数据中自带的校验码进行对比。二者不匹配则表明有错误产生,那么这个 Base58Check格式的数据就是无效的。例如,一个错误比特币地址就不会被钱包认为是有效的地址,否则这种错误会造成资金的丢失。
为了使用Base58Check编码格式对数据(数字)进行编码,首先我们要对数据添加一个称作“版本字节”的前缀,这个前缀用来明确需要编码的数 据的类型。例如,比特币地址的前缀是0(十六进制是0x00),而对私钥编码时前缀是128(十六进制是0x80)。 表4-1会列出一些常见版本的前缀。
接下来,我们计算“双哈希”校验码,意味着要对之前的结果(前缀和数据)运行两次SHA256哈希算法:
checksum = SHA256(SHA256(prefix+data))
在产生的长32个字节的哈希值(两次哈希运算)中,我们只取前4个字节。这4个字节就作为校验码。校验码会添加到数据之后。
结果由三部分组成:前缀、数据和校验码。这个结果采用之前描述的Base58字母表编码。下图描述了Base58Check编码的过程。
相同:
1) 哈希算法、Merkle树、公钥密码算法
https://blog.csdn.net/s_lisheng/article/details/77937202?from=singlemessage
2)全新的 SHA-3 加密标准 —— Keccak
https://blog.csdn.net/renq_654321/article/details/79797428
3)在线加密算法
http://tools.jb51.net/password/hash_md5_sha
4)比特币地址生成算法详解
https://www.cnblogs.com/zhaoweiwei/p/address.html
5)Base58Check编码实现示例
https://blog.csdn.net/QQ604666459/article/details/82419527
6) 比特币交易中的签名与验证
https://www.jianshu.com/p/a21b7d72532f
2. 以太坊钱包私钥和地址丢失了怎么办
1. 尝试通过电脑网盘恢复丢失的私钥。首先,打开电脑并识别到您的硬盘处于BitLocker加密状态。
2. 双击该硬盘以输入密码进行解密。
3. 成功解密后,您应该能够看到硬盘的大小及其内部内容。
4. 接下来,右键点击硬盘并选择“管理BitLocker”。
5. 在弹出的窗口中,选择“再次保存或打印安全密钥”选项。
6. 最后,选择“将密钥保存到文件”以重新获得您的密钥。
关于私钥的保存方法,请遵循以下几点建议:
1. 创建并保存备份的Keyfile或JSON文件。
2. 记住并保管好您的助记词。
3. 使用支持找回功能的数字钱包。
4. 手动抄录钱包私钥,并将其安全存放。
5. 不要轻信任何要求提供私钥以领取空投代币的信息,始终记住没有免费的午餐。
3. 公钥,私钥,助记词和 keystore
本文讨论的公钥、私钥、助记词及keystore,主要以比特币中为例,其他公链的原理和实现大体相似。其中,keystore是用于以太坊钱包存储私钥的一种方式。
在比特币中,私钥是一串由256位0和1组成的随机数字,理论上可以以抛硬币的方式模拟生成。实际情况下,使用操作系统底层提供的随机数生成器来创建256位私钥,通常为64位的16进制数。为了提高可读性,私钥常以base58编码方式呈现,这在导入钱包时尤为关键。
私钥至关重要,相当于比特币账户的钥匙,持有私钥的人拥有对账户的完全控制权。通常,私钥通过多种钱包形式保存,如纸质钱包、大脑记忆、或各种应用的钱包app。
公钥是基于私钥通过椭圆曲线加密算法得出的,它通过单向哈希运算产生比特币地址。类似地,其他公链的地址生成方式也大致遵循这一原理。
助记词是私钥的另一种形式,旨在通过生成一串英文单词来避免私钥因数字复杂性带来的记忆与复制错误。助记词的生成过程和原理在相关文章中有详尽介绍。
keystore是一种以太坊钱包用于加密私钥并保存为json文件的方式,相较于比特币未提供私钥加密保存的方案,keystore提供了额外的安全性。关于keystore的详细原理,有文章进行了深入阐述。
综上所述,公钥、私钥、助记词及keystore构成了数字货币钱包的核心要素,确保了资产的安全性与可访问性。
4. 以太坊密钥怎么获取
打开以太坊钱包,点击⭕内,然后打开高级模式,选择导出私钥即可
5. 什么是公钥、私钥、密码、助记词、Keystore
公钥、私钥、密码、助记词、Keystore是在使用数字货币钱包时,必须要弄清的概念:如果不搞清楚,很可能会造成数字资产的严重损失。
1.公钥:
相当于所属钱包的地址,可理解成银行账户。
公钥的地址可理解成银行卡号,是由公钥通过计算得来,就像银行先给你开户,后给你银行卡卡号。
钱包地址的主要用途是收款,也可以作为转账的凭证,就像别人汇款给你时你需要告诉他银行卡卡号一样。
常见的钱包地址样式:
比特币:普通地址:1开头、隔离见证地址:3开头
以太坊地址:0x开头:(包括基于以太坊平台代币)瑞波币地址:r开头。
莱特币地址:L开头。
2.私钥:
非常重要,相当于银行卡号+银行卡密码。
创建钱包后,输入密码即可导出私钥。私钥是由字母数字组成的字符串,一个钱包地址只有一个私钥且不能修改。私钥要离线保存,不要进行网络传输,可用纸张记录并保存。
主要用途,导入钱包。有了私钥就可以在同系列的任何一款钱包上,输入私钥并设置一个新的密码就可以把之前的A钱包的资产导入B钱包。比如手机丢了,只要你有私钥就可以恢复。
3.密码 :
相当于银行卡密码。
在创建数字货币钱包时,需要设置一个密码,一般要求不少于8个字符。
主要用途:①转账时需要输入密码,可理解成你用银行卡给别人转账需要输入密码;②用Keystore导入钱包时,必须输入这个密码。
密码可以进行修改或重置。输入原密码后,就可以直接修改新的密码了;但如果原密码忘记,可以用私钥或是助记词导入钱包,同时设置新的密码。数字货币钱包中,一个钱包在不同手机上可以用不同的密码,彼此相互独立,互不影响。
4.助记词
等于私钥=银行卡号+银行卡密码
由于私钥由64位字符串组成,不便于记录,非常容易抄错,于是就出现了助记词,方便用户记忆和记录。由12个单词组成,每个单词之间有一个空格,助记词和私钥具有同样的功能:只要输入助记词并设置一个新的密码,就可以导入钱包。
一个钱包只有一套助记词且不能修改。助记词只能备份一次,备份后,在钱包中便不会再显示。因此,在备份时一定要抄写下来,防止抄写错误,尽量多次检验。
5.Keystore:
Keystore+密码=私钥=银行卡号+银行卡密码、Keystore ≠ 银行卡号
Keystore相当于加密过后的私钥,在导入钱包时,只要输入Keystore 和密码,就能进入钱包了。这一点和用私钥或助记词导入钱包不一样,后两者不需要知道原密码,而是直接重置密码。
keystore进行交易转账等钱包操作,必须知道该keystore的密码。keystore的密码是无法更改的,一个keystore对应一个密码。但是可以通过该钱包的助记词,重新生成一个keystore。这个keystore可以用新的密码生成,重新生成新的keystore之后,最好将旧的keystore删除。
总结:
一个数字货币钱包创建完成后,公钥和私钥是成对出现的。公钥,私钥都是由字母,数字组成的较长的字符串。
keystore和助记词可以理解为私钥的另一种表现形式。助记词作为钱包私钥的友好格式,非常方便备份和导入。
地址可以通过私钥、助记词、keystore+密码,导入钱包找回。密码可以通过私钥、助记词,导入钱包重置密码。如果私钥、助记词、Keystore+密码,有一个信息泄漏,别人就可以拥有你钱包的控制权,钱包内的币就会被别人转移走。
私钥通过加密生成公钥,公钥转换一下格式生成地址。私钥可以推导出公钥,公钥可以推导出地址,但无法通过输出地址、公钥推导出私钥。
在生活中,银行开户是“开设银行账户—银行卡号—设置银行卡密码—开户成功
在币圈里,是先设置“密码”(私钥),再得到“银行账户”(公钥),最后给地址。对于钱包安全管理,主要注意防盗和防丢。防止私钥泄露及丢失。
注意事项:
1.关于各种骗局诱导交出私钥、助记词的行为,都要谨慎操作;
2.重视私钥、助记词、Keystore+密码的备份和保存!多重备份,多次备份,多重验证,防止抄写错误。
3.私钥不好备份的情况下,可选用备份助记词,具体根据钱包的备份要求。
4.不要进行联网备份,或通过微信、qq、邮箱等任何第三方工具进行传输发送你的私钥、助记词、keystore。不要截图。
5.备份内容放到安全、妥善的地方,并告诉家人(以防突发事故发生)
数字货币钱包的作用是安全存储资产,这是最重要的!从投资纪律来讲,本金安全是一切的基础。对于理财类的钱包,声称赚取收益高回报等,应该叫“数字资产理财”更恰当。你的资产他们可以随意动用拿去投资。你对资产没有完全的掌控权,如果投资顺利,本息安全,如果投资失败,血本无归。所以,请慎重使用这类钱包,应该注重的是资产的安全和私密性。
6. 什么是公钥、私钥、密码、助记词、Keystore
1. 公钥:相当于数字货币钱包的地址,可以理解为银行账户。公钥的地址是由公钥通过计算得来,类似于银行开户后给您的银行卡号。钱包地址主要用于接收款项,也可作为转账的凭证,类似于别人向您汇款时需要知道您的银行卡卡号。常见的钱包地址样式包括比特币的普通地址(以1开头)、隔离见证地址(以3开头)、以太坊地址(以0x开头,包括基于以太坊平台的代币)以及瑞波币地址(以r开头)和莱特币地址(以L开头)。
2. 私钥:非常重要,可以看作是银行卡号加上银行卡密码。创建钱包时,输入密码即可导出私钥。私钥由字母和数字组成的字符串构成,每个钱包地址只有一个私钥,且不可更改。私钥应当离线保存,避免进行网络传输,最好将其记录在纸上保存。私钥的主要用途是在同系列的任何一款钱包上导入资产,类似于您在丢失手机后,只要有私钥就可以恢复钱包。
3. 密码:相当于银行卡密码。在创建数字货币钱包时,需要设置一个不少于8个字符的密码。密码主要用于两个方面:一是在转账时需要输入密码,类似于使用银行卡给他人转账时需要输入密码;二是当使用Keystore文件导入钱包时,必须输入这个密码。密码可以进行修改或重置,如果您忘记原密码,可以使用私钥或助记词导入钱包,并设置新的密码。
4. 助记词:等于私钥,也可以理解为银行卡号加上银行卡密码。由于私钥由64位字符串组成,不便于记录,非常容易抄错,因此推出了助记词,方便用户记忆和记录。助记词由12个单词组成,每个单词之间用空格分隔。一个钱包地址只有一套助记词,且不能修改。助记词备份后,在钱包中便不会显示,因此务必在备份时仔细抄写,防止抄写错误,并多次核对。
5. Keystore:Keystore加上密码等于私钥,但Keystore不等同于银行卡号。Keystore文件相当于加密后的私钥。在导入钱包时,只需输入Keystore文件和密码即可。与使用私钥或助记词导入钱包不同,后者不需要原密码,可以直接重置密码。每个Keystore文件都有一个对应的密码,且密码无法更改。但是,可以通过钱包的助记词重新生成Keystore文件,新文件可以用新的密码生成。生成新Keystore后,最好删除旧的Keystore文件以保证安全。
总结:数字货币钱包创建后,公钥和私钥是成对出现的,它们都是由字母和数字组成的字符串。Keystore文件和助记词可以视为私钥的另一种表现形式。助记词作为钱包私钥的友好格式,非常便于备份和导入。钱包地址可以通过私钥、助记词或Keystore加密码导入钱包找回。密码可以通过私钥、助记词导入钱包并重置。如果私钥、助记词或Keystore加密码中的任何信息泄露,别人就可以控制您的钱包,里面的币就会被转移走。私钥可以推导出公钥,公钥可以推导出地址,但无法通过地址或公钥推导出私钥。
在生活中,银行开户是先开设账户,然后得到卡号和设置密码。在数字货币领域,则是先设置密码(私钥),然后得到账户地址(公钥),最后是地址。在钱包安全管理方面,主要要注意防盗和防丢。防止私钥泄露或丢失。注意事项包括:不要泄露私钥、助记词或Keystore加密码的信息;重视备份,并进行多次验证以防止错误;避免在线备份或通过第三方工具传输您的钱包密钥;将备份内容放在安全的地方,并告知家人以防不测。数字货币钱包的主要作用是安全存储资产,这是最重要的。在投资钱包时,应当注重资产的安全和私密性,避免投资失败导致损失。
7. 以太坊钱包私钥和地址丢失了怎么办
用电脑网盘可尝试恢复。
第一步,打开电脑,可以看到插入的一个硬盘处于BitLocker加密状态。
第二步,双击这个盘,输入密码进行解密操作。
第三步,当输入完正确的密码后,硬盘就能显示大小和查看里边的内容了。
第四步,这个时候,右键点击硬盘,选择管理BitLocker选项。
第五步,在弹出的窗口中选择,再次保存或打印安全密钥选项。
第六步,选择,将密钥保存到文件选项。
最后,密钥就可以重新获得了。
如何保存私钥,1、备用Keyfile或JSON,2、掌握自己的助记词档,3、用拥有找回专利的数字钱包,4、钱包私钥最好使用纸笔抄录,同时自己保存起来,5、切勿相信一切以索取私钥为理由的空投代币行为,要时刻记住,世上没有免费的午餐。
8. 2.在以太坊中,为了得到唯一的公钥,对私钥应用哪种算法
在以太坊中,为了得到唯一的公钥,对私钥应用算法:
1、生成一个随机的私钥(32字节)。
2、通过私钥生成公钥(64字节)。
3、通过公钥得到地址(20字节)。
9. 以太坊精度是几位
以太坊的私钥是一个256位的二进制数,因此猜对它的概率是2的256次方分之一,数值上大约是10的77次方分之一,也就是说分母是1后面77个0。
1、以太坊的单位,沿袭了科学界的传统,用做过杰出贡献的数学、密码学专家的名字命名。一次性向六位专家致敬,并且未来可能引入更多单位。以太坊的最小单位是Wei。
2、以太坊的私钥是一个256位的二进制数,因此猜对它的概率是2的256次方分之一,数值上大约是10的77次方分之一,也就是说分母是1后面77个0。
3、1个以太币=10的18次方Wei,但因为这个单位太小,好像Byte字节与KB、MB、GB的电脑存储单位一样,以太坊还有其他的单位:
Kwei(Babbage)=10的3次方Wei
Mwei(Lovelace)=10的6次方Wei
Gwei(Shannon)=10的9次方Wei
MicroEther(Szabo)=10的12次方Wei
MilliEther(Finney)=10的15次方Wei
Ether=10的18次方Wei
每个单位都还有个别名,即括号里的那个,每个别名又各有来历。老链哥找机会再逐个介绍。通常,小额支付使用Finney,计算Gas价格使用GWei。