译文出自:登链翻译计划
译者:翻译小组
校对:Tiny熊
在指南的第一部分中,我们在与模拟的以太坊网络进行交互时,涵盖了很多内容。此时,你至少应该对如何回答这些问题有一个模糊的概念:
什么是区块链,区块里有什么?
是什么让以太坊去中心化?
什么是以太币,为什么它是网络的必要组成部分?
在这篇文章中,我们将在这些概念的基础上,探讨对开发者的一些影响,如果你跳过或需要复习,请返回第1部分。
接下来做什么?
我们将从账户开始,更深入地了解你如何与以太坊网络交互。以太坊账户和Web2.0账户之间有一些显著的区别。
注:Web2.0是用来描述:引入用户生成内容的互联网时代的,例如社交媒体和博客。而以太坊和其他去中心化技术则称为是下一代互联网的一部分。Web3因此被Web3.js和Web3.py等库以及生态系统的其他地方使用。
Web2与Web3
在如今的网络中,很难集合账号。你得为每个社交媒体应用程序、新闻网站、配送服务、零售商和航空公司等等都注册一个账号。每一个账户都在其公司的服务器上,这使得你必须遵守他们的条款和条件、隐私政策和安全惯例。你的账户可以被冻结、删除、审查或由所在公司酌情更改。
Web3代表了账户管理的范式转变:只有你自己一个人拥有你的以太坊账户。当你创建一个账户时,它与任何公司无关,此账号并且可以在多个应用程序中使用。事实上,创建一个以太坊账户根本不需要与以太坊区块链进行交互。我们现在就来创造一个。
注:这个练习纯属教育目的。在明白安全影响之前,不要在账户中存储真实价值。否则有些错误是无法挽回的!
创建一个账户
和上次演练一样,依旧在IPythonshell中演示这些概念。如果你不是Python开发者,没问题。只要在概念上跟着走就可以了。
以太坊全网算力约578,467.09GH/s 挖矿难度约7,711.70T:据以太坊链上数据显示,当前以太坊全网算力约578,467.09GH/s,挖矿难度约7,711.70T。ETH当前价格:$3,134.90,交易费Gas均价:21.20Gwei,未确认交易数:61855。[2021/8/10 1:45:08]
环境设置
三步到位:
安装Web3.py、eth-tester和IPython。$pipinstallweb3web3ipython。
启动一个新的沙盒环境。$ipython
导入Web3模块。在:从web3导入Web3。
账户生成
让我们创建一个账户:
In:w3=Web3()#现在不需要providerIn:acct=w3.eth.account.create()#publicaddress:In:acct.addressOut:'0x33736Bf0Ac7A046eAC36648ca852B91EAe5f567A'#privatekey:In:acct.keyOut:HexBytes('0x7aca78f5e54...')
这就是创建账户所有要做的!没有注册过程,也没有和区块链或任何服务器交互。事实上,你可以完全断开与互联网的连接,仍然可以创建一个有效的以太坊账户。
在上面的代码中,你会发现一个账户的两个组成部分:一个公开地址和一个私钥。简单来说,私钥就是一个账户的密码。公开地址是由私钥衍生出来的可共享账号。从代码示例中可以看出,两者通常用十六进制数字表示。
注:以太坊用户和应用开发者不必了解账户生成过程的具体运作方式,但如果你有兴趣非常深入地了解,可阅读:理解助记词与HD钱包
使用账户
在区块链上影响变化的唯一方式是通过交易,每笔交易必须由账户签署。这是需要了解,且很重要的一点。
以太坊链上交易量上升13.06%:金色财经消息,据欧科云链OKLink数据显示,截至下午2时,以太坊24h链上活跃地址数逾64.12万,环比上升2.58%;链上交易量近746.62万ETH,环比上升13.06%;当前建议Gas费用161.42Gwei,环比下降15.06%。[2021/1/5 16:28:27]
账户可以发起转账以太币的交易,部署智能合约,或与合约交互。我们来简单探讨一下每个方式。
以太币转账
回顾一下,EthereumTesterProvider启用了一个以账户和充值了测试以太币种子的测试环境。我们先来查看一些测试账户和账户余额。
In:w3=Web3(Web3.EthereumTesterProvider())In:w3.eth.accountsOut:In:acct_one=w3.eth.accountsIn:w3.eth.get_balance(acct_one)Out:1000000000000000000000000
接下来,我们将介绍一个新的账户。
In:acct_two=w3.eth.accounts.create()In:acct_two.addressOut:'0x2FF32Bcc040e98EBa3c0ae2d8ad9C451a78d3E24'In:acct_two.keyOut:HexBytes('0x02af55504048265...f70e9965a3505ea')
然后把一些测试以太币送到新的账户上。
In:tx_hash=w3.eth.send_transaction({'from':acct_one,'to':acct_two.address,'value':10000000000})
这笔交易将立即执行,但一些重要的细节被隐藏起来。Web3.py很聪明,知道EthereumTesterProvider正在管理acct_one,而且我们正在使用测试环境。为方便起见,acct_one是"unlocked(解锁)"的,也就是说,该默认使用该账户来签署交易。
分析 | 以太坊30天ROI 持续走低 主流交易所相关交易量下滑:据TokenGazer数据分析显示,截止至7月30日11时,以太坊价格为$206.93,总市值为$22,262.76M,主流交易所交易量约为$124.10M,环比昨日缩水24.05%;以太坊对比特币汇率近阶段保持稳定;基本面方面,以太坊链上交易量有一定回升,活跃地址数、算力、链上DApp交易量平稳波动;以太坊30天开发者指数约为2.33;以太坊与BTC的关联度缓慢下滑,目前约为0.796;以太坊30天ROI 持续走低;ERC20代币总市值约为以太坊总市值的67.11%,保持稳定。[2019/7/30]
那么,如果从非解锁账户发起交易是什么样的呢?让我们从acct_two,一个不由EthereumTesterProvider管理的账户发送一些以太币。这个需要三个步骤。1)指定交易细节,2)签署交易,3)向网络广播交易。
#1)手动构造交易In:tx={'to':acct_one,'value':10000000,'gas':21000,'gasPrice':1,#priceonlypossibleineth-tester'nonce':0}#2)用私钥签名交易In:signed=w3.eth.account.sign_transaction(tx,acct_two.key)#3)发送”raw“原始交易In:tx_hash=w3.eth.sendRawTransaction(signed.rawTransaction)
让我们来分析一下。步骤1定义了一个Python字典,其中包含所需的交易字段。我们在第一部分学习了gas和gasPrice,但nonce可能是新关键字。在以太坊中,nonce只是账户的交易次数。以太坊协议会跟踪这个值,以防止双花。
由于这是acct_two进行的第一笔交易,所以它的nonce为0。如果你提供了错误的值,结果是无效的交易,并被Web3.py拒绝。
ValidationError:Invalidtransactionnonce:Expected0,butgot4
声音 | 以太坊核心开发者:希望结束对开发人员的威胁和攻击:据breakermag报道,全球110余位以太坊核心开发者共同发布了致以太坊社区的公开信。该公开信称,虽然Afri的推文确实是挑衅性的,但这些是以个人身份发表的意见。其中很多用户对此表示尊重,但以太坊社区中的一些其他人声称他参与野蛮阴谋,??要求他立即辞职,以及对Afri个人发出威胁。这种类似行为远非第一次,文中并列举一些类似事件,呼吁以太坊社区结束对开发人员的威胁和攻击行为,共同构建和谐社区。[2019/2/20]
请注意,当从acct_one发送交易时,仍然需要一个nonce,但EthereumTesterProvider会跟踪管理账户的交易计数,并为新的交易添加适当的nonce。
另一个细节你可能已经注意到了,从tx中缺少一个from值。这是因为,sign_transaction方法可以从发件人的私钥推断出发件人的地址。上面提到过,公开地址可以从私钥中推导出来,但私钥不能从公开地址反向推导出来。
最后,raw原始交易是以字节表示的交易数据和签名。在底层,sign_transaction与sendRawTransaction采用相同的编码。
部署智能合约
与智能合约的交互看起来与标准交易非常相似。
简单来说,智能合约是”活跃“在以太坊区块链上的程序,任何人都可以使用。当你准备好部署一个智能合约时,需要将代码编译成字节码,并将其作为一个data值包含在一个交易中。
bytecode="6080604052348015610...36f6c63430006010033"tx={'data':bytecode,'value':0,'gas':1500000,'gasPrice':1,'nonce':0}
除了需要更多的Gas外,合约部署交易中唯一的区别是没有to值。其余过程与标准的以太币转账相同。
与智能合约交互
行情 | 以太坊未确认交易笔数为42487笔:根据公开数据显示,目前以太坊的网络未确认交易笔数为42487笔,网络较为拥堵。[2018/7/3]
使用部署合约的交易格式类似。在这种情况下,to值指向合约地址,data值将根据正在执行的合约方法的输入而变化。
需要注意的是,像Web3.py这样的工具为合约的部署和交互提供了更直观的界面。
#与合约交互myContract=web3.eth.contract(address=address,abi=abi)twentyone=myContract.functions.multiply7(3).call()#部署新合约Example=w3.eth.contract(abi=abi,bytecode=bytecode)tx_hash=Example.constructor().transact()
签名
交易是影响区块链状态的唯一方式,但并不是账户的唯一的使用方式。仅仅是证明某个账户的所有权,其本身就很有用。
举个例子,OpenSea是一个以太坊市场,你可以用你的账户签名留言来竞拍待售物品。只有当拍卖到期或卖家接受你的报价时,才是真正的交易。同样,在向你展示一些账户细节之前,该应用程序使用签名信息作为一种认证形式。
与交易不同的是,签名信息不需要任何费用。他们没有向网络广播,也没有列入一个区块。签名信息只是用私钥签署后的一串数据。和期望的一样,发送者的私钥仍然是隐藏的,但接收者可以用数学方法证明发送者的公共地址。换句话说,无法冒充信息的发送者。
注:术语链上和链下是表示数据是否活跃在以太坊区块链上的缩写。例如,账户余额和智能合约状态是_链上管理_的,但消息签名却发生在_链下_。
我们将在以后的文章中深入探讨消息签名,但这里有一些伪代码可以让你了解工作流程。
#1.一串信息msg="amanaplanacanalpanama"#2.用私钥签名pk=b"..."signed_message=sign_message(message=msg,private_key=pk)#3.用任何方式发送签名信息`signed_message`#4.信息接收者解析出发送者的公共地址sender=decode_message_sender(msg,signed_message.signature)print(sender)#'0x5ce9454...b9aB12E'
Web3账户所涉问题
我们可以轻松创建以太坊账户:离线并与任何应用程序独立。这些账户可以用来签署信息或发送各种类型的交易。这对应用开发者意味着什么?
永久密码
这个世界一个残酷的现实是,没有密码恢复服务。如果你丢失了你的私钥,你就可以和这个账户吻别了。这就是真正的所有权的双刃剑。应用开发者有道德和义务帮助以太坊新人上岗,并教育他们认识到这一现实。(注:社交恢复型钱包可改善此类用户体验)。
新挑战
将新用户引入以太坊是有门槛的。正如你一直在学习的那样,有一些范式的转变并不是很明显。你可能要引导还没有以太坊账户的访客或没有以太币的用户支付交易费用。教育用户的成本取决于你的受众,但如果你能够优雅地引入新用户,整个生态系统将受益。
较少的账户管理功能
鉴于用户在你的应用之外创建账户,你可能会发现你的使用场景几乎不需要或根本不需要账户管理功能。
新的商业模式
数据挖掘不会消失,但这种新的账户所有权模式是Web2.0模式的一个健康的替代方案,在Web2.0模式下,公司拥有用户的每一点数据,并将其出售给出价最高的人。以太坊的智能合约平台提供了一个新的激励模型。
新的软件架构
在你的商业模式定义中,一个有趣的权衡将是如何处理链上与链下。正如我们讨论过的,消息签名不需要链上交互。也没有什么可以阻止你使用私人数据库来处理部分数据,而使用以太坊区块链来处理其他位数据或功能。需要考虑的权衡因素很多:可用性、成本、透明度、去中心化、隐私等等。
小结
这些都掌握了吗?检验一下:
以太坊账户与Web2.0中的账户有何不同?
以太坊账户可以在哪些方面使用?
以太坊账户对应用开发者有什么影响?
你可以生成的账户数量没有限制,你可以自由地将同一个账户用于多个应用程序,或者为每个应用程序创建一个新的账户。当一个公共区块链被描述为无需许可的,意思是:你和网络之间没有守卫人。因此,不要等着别人允许你建造。
本翻译由CellNetwork赞助支持。
来源:https://snakecharmers.ethereum.org/a-developers-guide-to-ethereum-pt-2/作者:MarcGarreau
参考资料
登链翻译计划:https://github.com/lbc-team/Pioneer
翻译小组:https://learnblockchain.cn/people/412
Tiny熊:https://learnblockchain.cn/people/15
第一部分:https://learnblockchain.cn/article/2092
第1部分:https://learnblockchain.cn/article/2092
Web3.js:https://web3js.readthedocs.io/
Web3.py:https://web3py.readthedocs.io/
IPython:https://ipython.org/
十六进制:https://simple.wikipedia.org/wiki/Hexadecimal
理解助记词与HD钱包:https://learnblockchain.cn/2018/09/28/hdwallet/
双花:https://en.wikipedia.org/wiki/Double-spending
OpenSea:https://opensea.io/
社交恢复型钱包:https://learnblockchain.cn/article/2011
CellNetwork:https://www.cellnetwork.io/?utm_souce=learnblockchain
免责声明:作为区块链信息平台,本站所发布文章仅代表作者个人观点,与链闻ChainNews立场无关。文章内的信息、意见等均仅供参考,并非作为或被视为实际投资建议。
本文来源于非小号媒体平台:
登链社区
现已在非小号资讯平台发布105篇作品,
非小号开放平台欢迎币圈作者入驻
入驻指南:
/apply_guide/
本文网址:
/news/9641881.html
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场
上一篇:
盘点零知识证明代表性项目:如何影响和塑造区块链生态系统?
区块链,是一种由多方共同维护,使用密码学保证传输和访问安全,能够实现数据一致存储、难以篡改、防止抵赖的分布式记账技术.
1900/1/1 0:00:00尊敬的用户:根据《Hotbit关于交易中心分区转区细则》,Hotbit定于2021年01月26日起将AYA(Aryacoin)、ARRO(ArroSocial)及UTU(UTUCoin)从“主力.
1900/1/1 0:00:00?上期《2021年2月牛市解读:避免牛市聒噪和亏钱,6种姿势你差点中标哪个》说了2种姿势,今天继续聊聊.
1900/1/1 0:00:00尊敬的BiONE用户:??BiONE将于2021年2月5日22:00正式下架VBTC/USDT,VBTT/USDT交易对,同时关闭VBTC,VBTT币种充提,请您于下架时间前撤销VBTC.
1900/1/1 0:00:00上周,美股上演了一出荒诞又热血的“华尔街激战”。一边是华尔街巨头、一边是上万散户,在这样一场大象和蚂蚁的战斗中——华尔街被撂翻,Robinhood成帮凶,民粹主义涌进金融市场,散户惨遭团灭,整个.
1900/1/1 0:00:002021年1月26日,知名的去中心化衍生品交易平台dYdX获得了1000万美元的B轮融资。dYdX获得本轮融资的一个主要原因是它的永续合约产品在2020年的爆发性增长.
1900/1/1 0:00:00