您正在查看: Ethereum-优秀转载 分类下的文章

IBFT共识概述

介绍

伊斯坦布尔拜占庭容错(IBFT)共识是受Castro-Liskov 99论文启发的。

了iBFT通过使用3相一致,从原来PBFT继承PRE-PREPARE,PREPARE和COMMIT。系统最多可以容忍验证器网络中的F故障节点N,其中N = 3F + 1。

执行

术语

  • Validator:阻止验证参与者。
  • Proposer:区块验证参与者,被选择在共识回合中提议区块。
  • Round:共识轮。一轮以提议者创建整体提议开始,以整体承诺或轮次更改结束。
  • Proposal:正在进行共识处理的新区块生成提案。
  • Sequence:投标的序号。序列号应大于所有先前的序列号。当前,每个建议的块高度是其关联的序列号。
  • Backlog:用于保存将来的共识消息的存储。
  • Round state:特定顺序和回合的共识消息,包括预准备消息,准备消息和提交消息。
  • Consensus proof:可以证明该区块已通过共识过程的区块的承诺签名。
  • Snapshot:验证者从上一个时期开始的投票状态。

共识

《伊斯坦布尔BFT共识协议》从回合开始,0验证者以循环方式从他们自己选择提议者。然后,提议者将提出一个新的整体提议,并将其与PRE-PREPARE消息一起广播。在收到PRE-PREPARE来自提议者的消息后,其他验证者将验证传入的提议并输入消息的状态PRE-PREPARED并广播PREPARE消息。此步骤是确保所有验证程序都在相同的序列和同一轮上工作。当验证器从其他验证器接收到ceil(2N/3)ofPREPARE消息时,验证器将切换到的状态PREPARED并进行广播COMMIT信息。此步骤是要通知其他验证者它接受建议的块,并将该块插入到链中。最后,验证等待ceil(2N/3)的COMMIT消息进入COMMITTED状态,再追加块链。

Istanbul BFT协议中的块是最终的,这意味着没有分叉,并且任何有效块都必须位于主链中的某个位置。为了防止故障节点生成与主链完全不同的链,每个验证器都会在将ceil(2N/3)接收到的COMMIT签名extraData插入到链中之前,将接收到的签名附加到标头中的字段。因此,所有块都是可自我验证的。但是,动态extraData会导致块哈希计算出现问题。由于来自不同验证器的同一块可以具有不同的COMMIT签名集,因此同一块也可以具有不同的块哈希。为了解决这个问题,我们通过排除COMMIT签名部分来计算块哈希。因此,我们仍然可以保持块/块哈希的一致性,并在块头中放入共识证明。

共识国家

Istanbul BFT是一种状态机复制算法。每个验证器维护一个状态机副本,以便达成块共识。IBFT共识中的各个州是,

  • NEW ROUND:提案人发送新的整体提案。验证程序等待PRE-PREPARE消息。
  • PRE-PREPARED:验证者已收到PRE-PREPARE消息并广播PREPARE消息。然后,它等待ceil(2N/3)的PREPARE或COMMIT消息。
  • PREPARED:验证器接收到ceil(2N/3)的PREPARE消息和广播COMMIT消息。然后,它等待ceil(2N/3)的COMMIT消息。
  • COMMITTED:验证器接收到ceil(2N/3)的COMMIT消息,并且能够将提出块插入blockchain。
  • FINAL COMMITTED:将一个新块成功插入到区块链中,并且验证器已准备好进行下一轮。
  • ROUND CHANGE:一个验证正在等待ceil(2N/3)的ROUND CHANGE同一提出全面数量的消息。
状态转换

  • NEW ROUND-> PRE-PREPARED:
    • 投标人从收集交易txpool。
    • 提议者生成一个整体提议并将其广播给验证者。然后进入PRE-PREPARED状态。
    • 每个验证器PRE-PREPARED在收到PRE-PREPARE具有以下条件的消息时都会进入:
      • 整体提案来自有效的提案者。
      • 块头有效。
      • 阻止提议的顺序和回合匹配验证者的状态。
    • 验证者将PREPARE消息广播到其他验证者。
  • PRE-PREPARED-> PREPARED:
    • 验证器接收ceil(2N/3)到有效PREPARE消息以进入PREPARED状态。有效消息符合以下条件:
      • 匹配顺序和舍入。
      • 匹配的块哈希。
      • 消息来自已知的验证器。
    • 验证器COMMIT在进入PREPARED状态时广播消息。
  • PREPARED-> COMMITTED:
    • 验证器接收ceil(2N/3)到有效COMMIT消息以进入COMMITTED状态。有效消息符合以下条件:
      • 匹配顺序和舍入。
      • 匹配的块哈希。
      • 消息来自已知的验证器。
  • COMMITTED-> FINAL COMMITTED:
    • 验证程序将ceil(2N/3)承诺签名附加到extraData并尝试将块插入到区块链中。
    • FINAL COMMITTED插入成功后,验证器进入状态。
  • FINAL COMMITTED-> NEW ROUND:
    • 验证者选择一个新的提议者,并开始一个新的回合计时器。
回合变更流程
  • 可以触发ROUND CHANGE以下三个条件:
    • 轮换计时器到期。
    • 无效的PREPREPARE讯息。
    • 块插入失败。
  • 当验证者注意到上述条件之一适用时,它将广播ROUND CHANGE消息以及建议的轮回编号,并等待ROUND CHANGE来自其他验证者的消息。根据以下条件选择建议的轮数:
    • 如果验证已收到ROUND CHANGE来自同行的消息,它选择具有最大回合数F + 1的ROUND CHANGE消息。
    • 否则,它将选择1 + current round number为建议的轮数。
  • 验证器每当收到相同提议轮数上的消息时,就会将接收F + 1到的ROUND CHANGE消息与自己的消息进行比较。如果接收到的ROUND CHANGE消息更大,则验证器将使用接收到的号码再次广播消息。
  • 当接收ceil(2N/3)的ROUND CHANGE在同提出的圆数量的消息,所述验证器退出轮变化循环,计算出新的提议,然后进入NEW ROUND状态。
  • 验证器跳出舍入循环的另一个条件是它通过对等同步接收到已验证的块。
提案人选择

目前,我们支持两种政策:轮循和粘性提议者。

  • 轮询:轮询是默认的提议者选择策略。在此设置中,提议者将在每个区块和每个回合中更改。
  • 粘性提议者:在粘性提议者设置中,仅在发生回合更改时提议者才会更改。
验证人名单投票

Istanbul BFT使用与Clique类似的验证者投票机制,并从Clique EIP复制大部分内容。每个时代的交易都会重置验证者投票,这意味着将添加或删除验证者的所有待处理投票都将重置。

对于所有交易块:

  • 提议者可以投一票以提议更改验证者列表。
  • 每个目标受益人的最新提议仅由单个验证者保存。
  • 随着链条的进行,将实时计票(允许并发提案)。
  • 达成多数共识的提案VALIDATOR_LIMIT立即生效。
  • 无效的建议书不会因为客户实施的简化而受到惩罚。
  • 提案生效后,必须放弃该提案的所有未决票(赞成和反对)。
未来的消息和积压

在异步网络环境中,可能会收到将来无法在当前状态下处理的消息。例如,验证程序可以COMMIT在上接收消息NEW ROUND。我们称这种消息为“未来消息”。当验证器收到将来的消息时,它将把消息放入待办事项中,并尝试在以后尽可能的处理。

常数

Istanbul BFT定义以下常量

  • EPOCH_LENGTH:默认:30000个块。检查点并重置未决投票的块数。
  • REQUEST_TIMEOUT:在以毫秒为单位触发一轮变更之前,每个共识轮都超时。
  • BLOCK_PERIOD:两个连续块之间的最小时间戳差异(以秒为单位)。
  • PROPOSER_POLICY:投标者选择策略,默认为轮询。
  • ISTANBUL_DIGEST:固定幻数0x63746963616c2062797a616e74696e65206661756c7420746f6c6572616e6365的mixDigest在伊斯坦布尔块识别块标题。
  • DEFAULT_DIFFICULTY:默认阻止难度,设置为0x0000000000000001。
  • EXTRA_VANITY:为提议者虚荣保留的固定数量的额外数据前缀字节。
    • 建议的32字节数,以保留当前的额外数据余量。
  • NONCE_AUTH:不可思议的随机数0xffffffffffffffff,可在添加验证器时进行投票。
  • NONCE_DROP:不可思议的随机数,0x0000000000000000用于对删除验证程序进行投票。
  • UNCLE_HASH:总是Keccak256(RLP([]))像叔叔在PoW之外毫无意义。
  • PREPREPARE_MSG_CODE:固定号码0。消息的消息代码PREPREPARE。
  • PREPARE_MSG_CODE:固定号码1。消息的消息代码PREPARE。
  • COMMIT_MSG_CODE:固定号码2。消息的消息代码COMMIT。
  • ROUND_CHANGE_MSG_CODE:固定号码3。用于消息的代码ROUND CHANGE的消息
  • VALIDATOR_LIMIT:通过授权或取消授权提议的验证者数量。
    • 必须floor(N / 2) + 1在链上执行多数共识。
块头

Istanbul BFT不会添加新的块标题字段。相反,它遵循Clique重新使用ethash标头字段的方式,如下所示:

  • nonce:有关受益人字段定义的帐户的提案人提案。

    • 应NONCE_DROP提议取消授权受益人为现有验证人。
    • 应该是NONCE_AUTH提议授权受益人为新的验证人。
    • 必须用零填充,NONCE_DROP或NONCE_AUTH
  • mixHash:固定0x63746963616c2062797a616e74696e65206661756c7420746f6c6572616e6365用于识别伊斯坦布尔街区的魔幻数字。

  • ommersHash:必须如此,UNCLE_HASH因为叔叔在PoW之外毫无意义。

  • timestamp:必须至少是父时间戳+ BLOCK_PERIOD

  • difficulty:必须填充0x0000000000000001。

  • extraData:签名人虚荣和RLP编码的Istanbul额外数据的组合字段,其中Istanbul额外数据包含验证者列表,提议者印章和提交印章。伊斯坦布尔的额外数据定义如下:

    type IstanbulExtra struct {
          Validators    []common.Address  //Validator addresses
          Seal          []byte            //Proposer seal 65 bytes
          CommittedSeal [][]byte          //Committed seal, 65 * len(Validators) bytes
    }

    因此,extraData形式为EXTRA_VANITY | ISTANBUL_EXTRAwhere|代表固定索引,以分隔虚荣和伊斯坦布尔额外数据(不是分隔符的实际字符)。

  • 前EXTRA_VANITY字节(固定)可以包含任意提议者虚荣数据。

  • ISTANBUL_EXTRA字节是根据所计算的RLP编码的Istanbul额外数据RLP(IstanbulExtra),其中RLP()RLP编码函数IstanbulExtra是Istanbul的额外数据。

    • Validators:验证者列表,必须按升序排列。
    • Seal:标头的提议者签名盖章。
    • CommittedSeal:承诺签名盖章清单作为共识证明。

散列哈希,提议者印章和承诺印章
ethash由于以下原因,Istanbul区块哈希计算与区块哈希计算有所不同:

  1. 提议者需要盖上提议者的印章,extraData以证明该区块已被选定的提议者签名。
  2. 验证者需要放入ceil(2N/3)已提交的印章作为共识证明,extraData以证明该区块已通过共识。

ethash除了需要处理之外,该计算仍然类似于块哈希计算extraData。我们计算字段如下:

投标人印章计算

到提议者印章计算时,提交的印章仍然是未知的,因此我们计算出那些未知数为空的印章。计算如下:

  • Proposer seal: SignECDSA(Keccak256(RLP(Header)), PrivateKey)
  • PrivateKey:提议者的私钥。
  • Header:与ethash标头相同,只是不同而已extraData。
  • extraData:vanity | RLP(IstanbulExtra),其中在IstanbulExtra,CommittedSeal并且Seal是空的阵列。
区块哈希计算

在计算块哈希时,我们需要排除提交的密封,因为该数据在不同的验证器之间是动态的。因此,我们CommittedSeal在计算哈希值时会创建一个空数组。计算公式为:

  • Header:与ethash标头相同,只是不同而已extraData。
  • extraData:vanity | RLP(IstanbulExtra),其中在IstanbulExtra,CommittedSeal是一个空数组。
共识证明

在将区块插入区块链之前,每个验证者都需要ceil(2N/3)从其他验证者那里收集已提交的印章,以构成共识证明。一旦接收到足够的承诺密封,这将填补CommittedSeal中IstanbulExtra,重新计算extraData,然后再插入块成blockchain。请注意,由于提交的密封可能因不同的来源而有所不同,因此如上一节所述,我们在计算块哈希值时会排除该部分。

承诺印章计算:

提交的印章是由每个验证者对哈希值COMMIT_MSG_CODE及其私钥的消息代码签名而计算的。计算如下:

  • Committed seal:SignECDSA(Keccak256(CONCAT(Hash, COMMIT_MSG_CODE)), PrivateKey)。
  • CONCAT(Hash, COMMIT_MSG_CODE):连接块哈希和COMMIT_MSG_CODE字节。
  • PrivateKey:签署验证者的私钥。

出处

GoQuorum中的Istanbul BFT实施基于EIP 650。自从打开EIP以来,它已进行了更新,以通过引入锁定来解决安全问题。

原文:https://docs.goquorum.consensys.net/en/stable/Concepts/Consensus/IBFT/

开源以太坊浏览器

1.blockscout

开源地址:https://github.com/poanetwork/blockscout

BlockScout是一个Elixir应用程序,允许用户搜索交易,查看帐户和余额,并验证整个以太坊网络上的智能合约,包括所有的叉子和侧链。

目前可用的块探测器(即Etherscan和Etherchain)是封闭系统,不能独立验证。随着以太坊侧链在私人和公共场合的不断扩散,需要透明的工具来分析和验证交易。

2.EthVM

开源地址:https://github.com/EthVM/EthVM

EthVM是一个开源的区块链浏览器,主要关注以太坊(虽然其他网络将受到支持)在MIT许可下,并以不同语言(即TypeScript,Kotlin和Solidity)的混合编写。

您可以使用EthVM作为工具来探索自定义专用网络或现有公用网络,或者作为ETL(提取,转换,加载)平台来对数据执行不同的分析。

3.etherparty/explorer

开源地址:https://github.com/etherparty/explorer

轻盈的以太坊块探险家

4.carsenk/explorer

开源地址:https://github.com/carsenk/explorer

以太坊Block Explorer基于etherparty/explorer

5.etherchain-light

开源地址:https://github.com/gobitfly/etherchain-light

Etherchain Light是一个使用NodeJS,Express和Parity构建的以太坊区块链资源管理器。它不需要外部数据库,并从后端以太坊节点即时检索所有信息。

6.toy-block-explorer

开源地址:https://github.com/curvegrid/toy-block-explorer

用Go编写的区块链资源管理器,用于了解如何构建与以太坊区块链一起使用的服务器端应用程序。

7.mini-eth-browser

开源地址:https://github.com/ismaelbej/mini-eth-browser

一个简单的以太坊块和事务探索器。由于它不使用数据库,因此某些操作很慢。

8.eth-explorer

开源地址:https://github.com/ethnamed/eth-explorer

简单的Nodejs以太坊资源管理器

9.Clixplorer

开源地址:https://github.com/Magicking/Clixplorer

10.ethereumproject / explorer

开源地址:https://github.com/ethereumproject/explorer

11. 模仿etherscan

https://github.com/bing-chou/etherscan-explorer

参考

https://www.cnblogs.com/huangenai/p/10075876.html

以太坊生态系统资源

生态系统资源

有关用于学习和理解以太坊生态系统的可用dapp,服务,著作和知识库的指南。

该资源旨在专注于生态系统的发展,但该相关资料还包括:

欢迎捐款!

可以随意拉取并提交请求,补充您想要添加(或删除!)的工具。如果添加新工具,请添加您认为新开发人员会理解的简短描述。

感谢众多贡献者包括@corbpage和@pakaplace为Meridio做出的贡献,并感谢@jpantunes以更合理的方式重组清单列表。

资源

钱包

网络钱包

  • MyEtherWallet -用于轻松,安全地与区块链进行交互的开源工具
  • MyCrypto - 用于生成以太币钱包,处理ERC-20代币以及更轻松地与区块链进行交互工具
  • Arkane - 基于Web的钱包专注于用户友好UX和DAPP整合。(适用于移动设备)
  • Torus - 开源客户端钱包重点放在UX
  • Portis -基于Web的钱包的植入,方便用户对你的DAPP
  • Eth lightwallet - 适用于Node和浏览器的轻量级JS钱包
  • SpankCard - 浏览器内以太坊钱包,支持支付渠道
  • Mnemonic generator - 生成单词助记符和相关的公用/专用密钥对。选择“以太坊”作为硬币以生成以太坊地址。对于truffle-hd-wallet钱包很有用。

手机钱包

  • Coinbase Wallet - 移动Dapp资源管理器和 钱包
  • Cipher - 移动Dapp资源管理器
  • Trust - 用于ERC代币的 移动钱包
  • Status - 适用于以太坊的免费开源移动操作系统
  • imToken - 功能丰富的数字资产移动钱包,支持多链资产管理,DApp浏览以及安全的私有价值交换
  • Jaxx - 手机和台式机钱包。集成了Shapeshift支持
  • WallETH - 原生Android以太坊钱包
  • eth-wallet-light - 针对移动设备进行了优化的轻量级JS钱包
  • Metamask - 带有ERC令牌的Mobile Ether钱包支持beta
  • WiniWallet - 具有多个DeFi投资的DAI稳定币钱包

硬件钱包

  • Trezor - 原始硬件钱包
  • Ledger - 支持多种加密货币和代币
  • KeepKey - 简单的硬件钱包

区块浏览器

  • Etherscan - 最受欢迎的集中式查看Eth交易和合同代码的方式
  • BlockScout - 由Ethprize资助,由POA开发的开源以太坊区块浏览器
  • TrueBlocks -TrueBlocks是软件库,应用程序,工具和示例的集合,可让您更快地检索以太坊区块链数据,(b)具有较高的信息内容,(c)以完全去中心化的方式,(d) (e)以高度免维护的方式。)
  • Etherchain lite - 您的私人以太坊链的轻量级区块链浏览器
  • EthStats - 以太坊区块链分析平台
  • Scout - 以太坊上智能合约的活动和事件日志的实时数据馈送
  • ethq - 为开发人员构建的,由dfuse 驱动的,最详细的块浏览器

汽油价格计算器和工具

  • EthGasStation - 用于估算交易价格与时间的网站
  • Petrometer - 汇总从指定以太坊地址发送的所有交易的每日和总汽油消耗

服务

  • Provable - 用于智能合约的具有真实性证明的区块链Oracle服务
  • Infura - API网关,因此您不必托管自己的ETH节点
  • Quiknode - 提升个人Parity/Geth节点的服务
  • Nodesmith - 免费API访问完整的以太坊主网和testnet节点,可以像本地节点一样使用
  • dfuse - Slick区块链API构建世界一流的应用程序
  • Regis - 数字资产注册表框架
  • Treum - 如果用例面向业务流程(以前是Viant),只需考虑将Treum用作后端
  • uPort - 整体身份解决方案
  • Ether Address Lookup - Chrome扩展程序,用于网络钓鱼防护和Eth地址突出显示
  • Netstats - 以太坊网络统计
  • ENS - ENS提供了一种安全且分散的方式,可以使用简单易读的名称来处理区块链上和下的资源
  • Name Bazaar - 通过以太坊名称服务注册的名称交换的对等市场
  • Quantstamp - 一种服务,提供收费的自动和手动智能合约安全性审核
  • SmartCheck - 对Solidity源代码进行静态分析以获取安全漏洞和最佳实践
  • MD4 Online Hash Function - 使用各种哈希算法选项对输入进行哈希的工具
  • iExec SDK - 使智能合约能够脱链执行功能或应用程序。支持作为Docker映像提供的所有旧版应用程序。
  • Incentivai - 通过使用ML代理进行仿真来测试智能合约经济性
  • Arkane - A wallet provider for Dapps - 提供API网关,并为Dapps及其用户提供钱包和钱包管理。
  • Aave SDK - JavaScript库,可与作为分散贷款市场ETHLend的Aave生态系统的API连接。
  • Rockside Cloud - 以太坊网络访问提供商和财团区块链构建商
  • Chainstack - 共享和专用的以太坊节点即服务
  • BUIDLHub - 在传统的Web服务和以太坊之间创建自动化的工作流。支持bot,webhooks,自定义dapp集成等。

知识/教育

安全最佳实践

Solidity 游戏!

Scaling

参考

治理

  • Ethresear.ch - 参与以太坊研究工作的半公开论坛,包括但不限于:Casper,Sharding,EVM改进,加密经济学,等离子和状态通道
  • Fellowship of Ethereum Magicians - 该讨论区促进整个以太坊社区中个人之间的有意义的交流
  • EIPs - 的复仇改进建议库
  • Aragon Research Forum - 与Aragon研究工作相关的长篇讨论,包括治理,经济学和令牌工程

去中心化交易所

安全分散数据协议

  • Stow - 在我们的组件和SDK分钟您的用户安全地存储和共享数据。前身为Linnia。

激励/货币化工具

  • Gitcoin - 资助开源或寻找开源工作的赏金网络
  • CodeFund - 开源广告平台

很棒的清单

去中心化金融(DeFi)

  • ETHLend - 分散的点对点借贷市场,使世界各地的人们都能获得贷款或成为贷方。
  • Aave Pay - Aave Pay允许用户使用其加密货币以FIAT货币向银行帐户支付。
  • rTrees - 一种无损捐赠应用程序,用于使用DeFi兴趣来种植真实的树木。

转载:https://github.com/ConsenSys/ethereum-developer-tools-list

以太坊开发者工具列表

以太坊开发者工具列表

这是一份关于在以太坊上开发应用程序的优质工具清单指南,其中包含一些工具、组件、应用、平台以及服务等。

该列表的创建受到ConsenSys产品经理的推动,他们认为有必要在初级开发与经验丰富的区块链开发人员之间更好地共享工具,开发模式和组件。

该资源旨在专注于开发人员工具,但还包括一些生态系统资源:

以太坊生态系统资源,关于有用的DApp,教育资源,钱包和服务。

欢迎捐款!

可以随意拉取并提交请求,补充您想要添加(或删除!)的工具。如果添加新工具,请添加您认为新开发人员会理解的简短描述。

感谢众多贡献者包括@corbpage和@pakaplace为Meridio做出的贡献,并感谢@jpantunes以更合理的方式重组清单列表。

  • 没有有效产品的项目将不会被添加。

  • 不推荐使用或不再维护的项目将被删除。

  • 没有开放源代码或开发者审核发现是付费/受限制服务的项目将得到进一步审查。

^以上规则公平吗?在此处分享您的想法:

https://github.com/ConsenSys/ethereum-developer-tools-list/pull/70

目录

新开发者从这里开始

  • Solidity - 最受欢迎的智能合约语言。
  • Truffle - 最受欢迎的智能合约开发,测试和部署框架。通过npm安装cli,然后从此处开始编写您的第一个智能合约。
  • Metamask - Chrome扩展程序钱包,可与Dapps进行交互。
  • Truffle boxes - 以太坊生态系统的打包组件。
  • OpenZeppelin Starter Kits - 开发人员的多合一入门组件,可快速启动其受智能合约支持的应用程序。包括Truffle,OpenZeppelin SDK,OpenZeppelin / contracts-ethereum-package EVM经审核的智能合约EVM软件包,react-app和rimble,易于设计。
  • EthHub.io - 以太坊的全面信息概述-它的历史,治理,未来计划和开发资源。
  • EthereumDev.io - 关于以太坊智能合约编程入门的权威指南。
  • Cobra - 一个快速,灵活,简单的以太坊智能合约开发环境的框架。将智能合约,测试和部署到以太坊虚拟机(EVM)上。
  • Kauri.io - 基于Web3的社区和新兴技术的知识平台。分享精选内容,并就最新,高质量的技术文章和系列进行协作。 请查看“入门”社区以学习基础知识。
  • dfuse - Slick 区块链 API 可以构建世界一流的应用程序。
  • Biconomy - 通过使用简单易用的SDK启用元交易来在dapp中进行无Gas交易。

开发者工具

开发智能合约

智能合约语言

  • Solidity - 以太坊智能合约编程语言。
  • Vyper - 新的实验性类python编程语言。

框架

  • Truffle - 最受欢迎的智能合约开发,测试和部署框架。Truffle套件包括 Truffle, Ganache, 和 Drizzle. 在这里深入了解松露
  • Embark - DAPP开发框架
  • Waffle - 先进的智能合同开发和测试框架,体积小,灵活,快捷(基于ethers.js)
  • Dapp - DApp开发的框架,DApple的继承者
  • Etherlime - 基于ethers.js的框架用于Dapp部署
  • Parasol - 敏捷的智能合同开发环境,测试,部署INFURA,合约文件等。它具有灵活,不受限制的设计以及无限的可定制性。
  • 0xcert - 用于构建去中心化应用程序的JavaScript框架
  • OpenZeppelin SDK - OpenZeppelin SDK:一套工具,可帮助您开发,编译,升级,部署智能合约并与之交互。
  • sbt-ethereum - 一个基于选项卡的,基于文本的控制台,用于智能合约的交互和开发,包括钱包和ABI管理,ENS支持和高级Scala集成。
  • Brownie - Brownie是一个Python框架,用于部署,测试以太坊智能合约并与之交互。
  • Cobra - 一个快速,灵活,简单的开发环境的框架,用于以太坊智能合约的测试和部署。

集成开发环境

其他工具

测试区块链网络

  • ethnode - 运行以太坊节点(Geth)进行开发,简单执行 npm i -g ethnode && ethnode.
  • Ganache - 具备UI和日志的区块链测试应用
  • Kaleido - 使用Kaleido来建立联盟区块链网络。非常适合PoC和测试
  • Besu Private Network - 在Docker容器中运行Besu节点的专用网络Orion -PegaSys进行私人交易的组件 Artemis - PegaSys的以太坊2.0信标链的Java实现。
  • Cliquebait - 使用类似于真实区块链网络的docker实例简化智能合约应用程序的集成和测试
  • Local Raiden - 在Docker容器中运行本地Raiden网络以进行演示和测试
  • Private networks deployment scripts - 专用PoA网络的现成部署脚本
  • Local Ethereum Network - 专用PoW网络的现成部署脚本
  • Ethereum on Azure - 联盟以太坊PoA网络的部署和治理
  • Ethereum on Google Cloud - 基于工作量证明构建以太坊网络
  • Infura -以太坊API访问以太坊网络(Mainnet,Ropsten,Rinkeby,Goerli,Kovan)
  • CloudFlare Distributed Web Gateway - 通过Cloudflare提供对以太坊网络的访问,而不是运行自己的节点
  • Chainstack - 共享和专用的以太坊节点即服务(Mainnet,Ropsten)

测试以太币水龙头

与以太坊通信

前端以太坊API

  • Web3.js - Javascript Web3
  • Eth.js - Javascript Web3替代者
  • Ethers.js - Javascript Web3替代,有用的实用程序和钱包功能
  • light.js 为轻客户端优化的高级反应式JS库。
  • Web3Wrapper - Typescript Web3替代者
  • Ethereumjs - 以太坊的实用程序功能集合,例如ethereumjs-utilethereumjs-tx
  • flex-contractflex-ether - 零配置的高级库,用于与智能合约进行交互并进行交易。
  • ez-ens - ens-简单的零配置以太坊域名服务地址解析器。
  • web3x - web3.js的TypeScript端口。好处包括小巧的构造和全类型的安全性,包括与合同进行交互时的安全性。
  • Nethereum - 跨平台的以太坊开发框架
  • dfuse - 使用TypeScript实现的dfuse Ethereum API 以太坊API库
  • Drizzle - Redux库将前端连接到区块链
  • Tasit SDK -一个React Native库,使用在移动端与以太坊进行交互。
  • useMetamask - 一个自定义的React Hook来管理以太坊ĐApp项目中的Metamask
  • WalletConnect - 用于将电子钱包连接到分散应用程序(DApp)的开放协议
  • Subproviders - 与Web3-provider-engine 结合使用的几个有用的子提供商(包括用于向您的dApp添加Ledger硬件钱包)
  • ethvtx - 支持以太坊&框架无关的Redux存储配置。文档
  • 严格类型-Javascript 替代者
  • ChainAbstractionLayer - 使用单个界面与不同的区块链(包括以太坊)进行通信。
  • Delphereum - 以太坊区块链的Delphi接口,允许开发适用于Windows,macOS,iOS和Android的dApp开发。
  • Torus - 源SDK构建dapps的无缝衔接的UX
  • Fortmatic - 一种易于使用的SDK,无需扩展或下载即可构建web3 dApp。
  • Portis - 具有SDK的非托管钱包,可轻松与DApp进行交互而无需安装任何东西。

后端以太坊API

  • Web3.py - Python Web3
  • Web3.php - PHP Web3
  • Ethereum-php - PHP Web3
  • Web3j - Java Web3
  • Nethereum - .Net Web3
  • Ethereum.rb - Ruby Web3
  • Web3.hs - Haskell Web3
  • KEthereum - Kotlin Web3
  • Eventeum - 由Kauri用Java编写的以太坊智能合约事件和后端微服务之间的桥梁
  • Ethereumex - 以太坊区块链的Elixir JSON-RPC客户端
  • Ethereum-jsonrpc-gateway - 一个网关,允许您运行多个以太坊节点以实现冗余和负载平衡。可以作为Infura的替代品(或在其之上)运行。用Golang写的。
  • EthContract - 一组帮助在Elixir中查询ETH智能合约的助手方法
  • Ethereum Contract Service - 一种MESG服务,可根据其地址和ABI与任何以太坊合约进行交互。
  • Ethereum Service - 一种MESG服务,用于与以太坊中的事件进行交互并与其进行交互。
  • Marmo - Python,JS和Java SDK,以简化与以太坊的交互。使用中继器将交易成本分担给中继器。

开箱即用工具

  • Truffle boxes - 以太坊生态系统的打包组件
  • Besu Private Network - 在Docker容器中运行Besu节点的专用网络
  • Testchains - 用于快速响应(PoA)的预配置由.NET开发
  • Blazor/Blockchain Explorer - Wasm区块链浏览器(功能示例)
  • Local Raiden - 在Docker容器中运行本地Raiden网络以进行演示和测试
  • Private networks deployment scripts - 专用PoA网络的现成部署脚本
  • Parity Demo-PoA Tutorial - 分步教程,用于构建具有2个节点且具有Parity授权回合共识的PoA测试链
  • Local Ethereum Network - 专用PoW网络的现成部署脚本
  • Kaleido - 使用Kaleido来建立联盟区块链网络。非常适合PoC和测试
  • Cheshire - CryptoKitties API和智能合约的本地沙盒实现,可以作为松露盒使用
  • aragonCLI - aragonCLI用于创建和开发Aragon应用程序和组织。
  • ColonyJS - JavaScript客户端,提供用于与Colony Network智能合约进行交互的API。
  • ArcJS - 便于javascript应用程序访问DAOstack Arc以太坊智能合约的库。
  • Arkane Connect - JavaScript客户端,提供用于与Arkane Network进行交互的API,Arkane Network是用于构建用户友好的dapp的钱包提供商。
  • Blocknative - Assist.js是可嵌入的小部件,可提高Dapp的可用性。该工具以编程方式识别并概述了清晰的操作,供最终用户在与MetaMask进行交互时应遵循的操作,以克服(甚至防止)常见的陷阱和障碍。
  • web3-react - 用于构建单页以太坊dApp的React框架

以太坊ABI(应用程序二进制接口)工具

  • ABI decoder - 用于解码以太坊交易中的数据参数和事件的库
  • ABI-gen - gen-从合同ABI生成Typescript合同包装。
  • Ethereum ABI UI - UI-从以太坊合约ABI自动生成UI表单字段定义和相关的验证器
  • headlong - Java中类型安全的合约ABI和递归长度前缀库
  • One Click dApp - 使用ABI在唯一的URL上快速的创建dApp前端页面。
  • Truffle Pig - 一种开发工具,提供简单的HTTP API来查找和读取Truffle生成的合同文件,以便在本地开发期间使用。通过http提供新的合同ABI。
  • Ethereum Contract Service - 一种MESG服务,可根据其地址和ABI与任何以太坊合约进行交互。
  • Nethereum-CodeGenerator - CodeGenerator-基于Web的生成器,可基于Solidity智能合约创建基于Nethereum的C#接口和服务。

模式和最佳做法

智能合约开发的模式
可升级性

基础设施

以太坊客户端

  • Besu - 在Apache 2.0授权开发和用Java编写的开源以太坊客户端。该项目由Hyperledger托管。
  • Geth - Go客户端
  • Parity - Rust客户端
  • Aleth - C++ 客户端
  • Nethermind - .NET 客户端
  • Infura - 一种托管服务,提供符合以太坊客户端标准的API
  • Trinity -使用Python客户端 py-evm
  • Ethereumjs - 使用ethereumjs-vm的JS客户端
  • Seth - Seth是一个以太坊客户端工具,就像“命令行的MetaMask”一样
  • Mustekala - Metamask的以太坊轻客户端项目
  • Exthereum - Elixir客户
  • EWF Parity - Tobalaba测试网络的Energy Web Foundation客户端
  • Quorum - JP Morgan授权的以太坊支持数据隐私的实现
  • Mana - 用Elixir写的以太坊全节点实现。
  • Chainstack - 提供共享和专用Geth节点的托管服务
  • QuikNode - 具有API访问和节点即服务的区块链开发云。

存储

  • IPFS - 分散存储和文件引用
    • Mahuta - 具有附加搜索功能的IPFS存储服务,以前是IPFS-Store
    • OrbitDB - IPFS之上的分散式数据库
    • JS IPFS API - 使用JavaScript实现的IPFS HTTP API客户端库
    • TEMPORAL - 易于在IPFS和其他分布式/分散式存储协议中使用的API
    • PINATA - 使用IPFS的最简单方法
  • Swarm - 分布式存储平台和内容分发服务,以太坊的数据存储服务层
  • Infura -托管IPFS API网关和固定服务
  • 3Box Storage - 用于用户控制的分布式存储的api。建立在IPFS和Orbitdb之上。

讯息传递

  • Whisper - DApp相互通信的通信协议,这是以太坊web3堆栈的基础层服务
  • DEVp2p Wire Protocol - 运行以太坊/低语的节点之间的对等通信
  • Pydevp2p - RLPx网络层的Python实现
  • 3Box Threads - API,使开发人员能够持久地实现IPFS,或在内存中实现对等消息传递。

测试工具

  • Truffle Teams - 零配置持续集成松露项目
  • Solidity code coverage - Solidity代码覆盖率工具
  • Solidity coverage - Solidity 智能合约的代码覆盖率
  • Solidity function profiler - Solidity 合约功能分析器
  • Sol-profiler - 替代和更新的Solidity智能合约分析器
  • Espresso - 快速,并行,热加载的Solidity测试框架
  • Eth tester - 用于测试以太坊应用程序的工具套件
  • Cliquebait - 使用与真实区块链网络非常相似的Docker实例简化智能合约应用程序的集成和接受测试
  • Hevm - hevm项目是以太坊虚拟机(EVM)的实现,专门用于单元测试和调试智能合约
  • Ethereum graph debugger - Solidity 图形化调试器
  • Tenderly CLI - 通过可读的堆栈跟踪加快开发速度
  • Solhint - 为Solidity智能合约验证提供安全性,样式指南和最佳实践规则
  • Ethlint - 用于识别和修复Solidity(以前为Solium)中的样式和安全问题
  • Decode - npm软件包,它将tx提交到本地testrpc节点的解析,使它们更具可读性和易懂性
  • truffle-assertions - 一个npm软件包,其中包含其他断言和实用程序,用于测试带有松露的Solidity智能合约。最重要的是,它增加了断言是否已发出特定事件的能力。
  • Psol - 具有mustache.js样式的语法,宏,条件编译和自动远程依赖关系包含的Solidity词法预处理器。
  • solpp -具有全面指令和表达式语言,高精度数学和许多有用的辅助函数的Solidity预处理器和帮助插件。
  • Decode and Publish – 解码和发布原始的以太坊TX。类似于https://live.blockcypher.com/btc-testnet/decodetx/
  • Doppelgänger - 一个用于在单元测试期间模拟智能合约依赖关系的库。
  • rocketh - 一个简单的库来测试以太坊智能合约,允许使用任何web3库和测试运行器。
  • pytest-cobra - PyTest插件,用于测试以太坊区块链的智能合约。

安全工具

  • MythX - 以太坊开发人员的安全验证平台和工具生态系统
  • Mythril - 开源EVM字节码安全性分析工具
  • Oyente - 替代静态智能合约安全性分析
  • Securify - 安全扫描器以太坊智能合约
  • SmartCheck - 静态智能合约安全分析器
  • Ethersplay - EVM反汇编程序
  • Evmdis - 替代EVM反汇编程序
  • Hydra - 框架cryptoeconomic合同的安全性,分散的治安悬赏
  • Solgraph - 可视化Solidity控制流程以进行智能合约安全性分析
  • Manticore - 智能合约和二进制文件上的符号执行工具
  • Slither - 一个Solidity静态分析框架
  • Adelaide - SECBIT静态分析扩展到Solidity编译器
  • solc-verify - 用于Solidity智能合约的模块化验证器
  • Solidity security blog - 已知攻击媒介和常见反模式的完整列表
  • Awesome Buggy ERC20 Tokens -受影响的代币中ERC20智能合约中的漏洞的集合
  • Free Smart Contract Security Audit - Callisto Network提供的免费的智能合约安全审核
  • Piet - 可视化Solidity体系结构分析器

监控方式

  • Alethio - 一个先进的以太坊分析平台,提供实时监控,洞察和异常检测,令牌指标,智能合约审计,图形可视化和区块链搜索。还可以探索以太坊去中心化交易所的实时市场信息和交易活动。
  • amberdata.io - 提供实时监控,洞察力和异常检测,令牌指标,智能合约审计,图形可视化和区块链搜索。
  • Neufund - Smart Contract Watch - 一种监视大量智能合约和交易的工具
  • Scout - 以太坊上智能合约的活动和事件日志的实时数据馈送
  • Tenderly - 一种平台,可通过Web仪表板的形式为用户提供可靠的智能合约监控和警报,而无需用户托管或维护基础架构
  • Chainlyt - 使用已解码的交易数据探索智能合约,查看合约的使用方式以及通过特定功能调用搜索交易
  • BlockScout - 一种用于检查和分析基于EVM的区块链的工具。唯一以太坊网络的功能齐全的区块链浏览器。
  • Terminal - 用于监视dapp的控制面板。终端可用于监视用户,dapp,区块链基础设施,交易等。 infrastructure, transactions and more.
  • Ethereum-watcher - 用Golang编写的可扩展框架,用于侦听链上事件并做一些响应。

其他杂项工具

  • aragonPM - 由aragonOS和Ethereum支持的去中心化软件包管理器。aragonPM支持对软件包升级进行分散式管理,从而消除集中式故障点。
  • Truffle boxes - 用于快速构建DApp的打包组件
    • Cheshire - CryptoKitties API和智能合约的本地沙盒实现,可以作为松露盒使用
  • Solc - Solidity 编译器
  • Sol-compiler -项目级Solidity编译器
  • Solidity cli - 更快,更轻松,更可靠地编译Solidity代码
  • Solidity flattener - Solidity项目组合到平面文件实用程序。对于可视化导入的合同或在Etherscan上验证合同很有用
  • Sol-merger - 替代方案,将所有导入合并到单个文件中以签订固定合同
  • RLP - JavaScript中的递归长度前缀编码
  • eth-cli - 一系列CLI工具的帮助以太坊学习和开发
  • Ethereal - Ethereal是用于管理以太坊中常见任务的命令行工具
  • Eth crypto - 以太坊的加密javascript函数以及将其与web3js和solidity结合使用的教程
  • Parity Signer - 移动应用程序允许签署交易
  • py-eth - 以太坊生态系统的Python工具集合
  • truffle-flattener - 合并在Truffle框架下开发的Solidity的所有依赖项
  • Decode - npm软件包,它将tx提交到本地testrpc节点的解析,使它们更具可读性和易懂性
  • TypeChain - 以太坊智能合约的Typescript绑定
  • EthSum - 一个简单的以太坊地址校验和工具
  • PHP based Blockchain indexer - 允许索引块或侦听PHP中的事件
  • Purser - JavaScript的基于以太坊的钱包通用钱包工具。支持软件,硬件和Metamask-使所有钱包进入dApp开发的一致且可预测的界面。
  • Node-Metamask - 从node.js连接到MetaMask
  • Solidity-docgen - Solidity项目的文档生成器
  • Ethereum ETL - 将以太坊区块链数据导出到CSV或JSON文件
  • prettier-plugin-solidity - solidity-用于格式化Solidity代码的漂亮插件
  • Unity3dSimpleSample - 以太坊和Unity集成演示
  • Flappy - 以太坊和Unity集成演示/样本
  • Wonka - Nethereum业务规则引擎演示/样本
  • Resolver-Engine - 一组用于标准化框架中Solidity导入和工件解析的工具。
  • eth-reveal - 检查事务的节点和浏览器工具-使用在线找到的ABI尽可能解码方法,事件日志和任何还原原因。
  • Ethereum-tx-sender -一个用Golang编写的有用的库,用于可靠地发送交易-提取一些棘手的底层细节,例如气体优化,随机数计算,同步和重试。
  • truffle-plugin-verify - 从Truffle命令行在Etherscan上无缝验证合同源代码。

智能合约标准和类库

ERCs - 以太坊评论提案库

  • 代币
    • ERC-20 - 同质化资产的原始代币合同
    • ERC-721 - 非同质化资产的代币标准
    • ERC-777 - 替代资产的改进令牌标准
    • ERC-918 - 可采矿代币标准
  • ERC-165 - 创建一种标准方法来发布和检测智能合约实现的接口。
  • ERC-725 - 密钥管理和执行的代理合同,用于建立区块链身份。
  • ERC-173 - 合同所有权的标准接口

流行的智能合约库

第二层基础架构开发人员指南

可扩展性

付款渠道

Plasma

  • Learn Plasma - 网站作为节点应用程序,始于康奈尔大学的2018 IC3-以太坊加密新手训练营,涵盖所有Plasma用例(MVP /现金/借记)
  • Plasma MVP - OmiseGO的最小可行Plasma研究实施
  • Plasma MVP Golang -Golang实施和最小可行Plasma规范的扩展
  • Plasma Guard - 在需要时自动观察和挑战或退出Omisego Plasma网络。
  • Plasma OmiseGo Watcher - 与Plasma OmiseGo网络互动并通知任何拜占庭事件。

侧链

隐私/保密

zkSNARKs
  • ZoKrates - 以太坊上的zkSNARKS的工具箱
  • The AZTEC Protocol - 以太坊网络上的机密交易,在以太坊主网上实时实施
  • Nightfall - 将任何ERC-20 / ERC-721令牌设为私人-开源工具和微服务
  • Proxy Re-encryption (PRE)
    NuCypher Network - 代理重新加密网络,可在分散系统中实现数据保密
    pyUmbral -门限代理重新加密密码库
    ** NuFHE - NuFHE -GPU加速的FHE库

可扩展性+隐私

ZK-STARKs

预建的UI组件

转载:https://github.com/ConsenSys/ethereum-developer-tools-list

让区块链浏览器收录你的 ERC20 代币

如果想让其他浏览器显示新发的代币,需要主动提交代币信息,对方审核通过后,即可显示。

打开网址https://etherscan.io,在此处输入 token 的智能合约地址,如下图:

搜索后,如下图:

按下图指示,点击“verify and publish”来发布代码,

由于读者已经发布了代码,这里就找了几张图贴出来,以供参考。

步骤一:

步骤二:

步骤三:

若出现如下图,即表示收录成功。

转载:https://my.oschina.net/u/3050295/blog/1982504