Solidity与Web3.js:区块链开发的关键技术
1. Solidity语言基础与安全问题
Solidity是一种用于区块链智能合约开发的语言,它处于不断发展和完善的过程中,并且有着详细的文档说明。在智能合约开发中,关键字的使用至关重要。例如, internal
关键字可用于限制关键函数的作用域,防止外部函数调用执行这些函数。但像 initWallet
函数不能设为 internal
,因为它需要作为公共函数,并且要在 Wallet
合约的构造函数中被调用。
曾经,由于缺少如 internal
和 only_uninitialized
这类关键字,导致了数百万美元的损失。这凸显了智能合约审计的重要性,需要专业的专家来进行审计,否则可能会频繁面临此类风险。
2. Web3.js简介
Web3.js是一个用JavaScript编写的特殊应用程序编程接口(API)库,它能将我们的网页浏览器与以太坊区块链节点连接起来。在深入了解Web3.js之前,我们先来看看它与geth、Mist的区别:
| 工具 | 通信方式 |
| ---- | ---- |
| Mist | IPC |
| geth | IPC |
| Web3.js | 远程过程调用(RPC) |
在以太坊生态系统中,IPC通常在本地计算机上工作,geth会在计算机的本地文件系统中创建一个名为 geth.ipc
的IPC管