Flutter / Dart生成以太坊地址

Flutter是采用Dart语言的跨平台应用开发框架,目前已经支持ios、安卓和web等多个平台。本文将介绍如何在Flutter应用中生成以太坊地址,如果你要开发一个手机钱包,或者要对接以太坊区块链,相信这篇文章会对你所帮助。

1、web3dart简介

作为一个新的框架,适合Flutter的以太坊开发包并没有太多选择,web3dart算是相对完善一些的Dart实现,它包含了JSON RPC封装、离线签名、ABI编解码等重要的特性,其目标是提供dart版的web3.js,能够适应绝大多数Flutter应用对接以太坊区块链的需求。

web3dart的安装方法很简单,首先在项目的pubspec.yaml中添加web3dart依赖项。例如:

name: hubwiz_tutorial
dependencies:
  web3dart: 
    git: git://github.com/simolus3/web3dart.git

然后执行如下命令更新项目依赖:

~/hubwiz_tutorial$ pub get

如果希望快速掌握Flutter / Dart应用对接以太坊区块链的方法,推荐 汇智网的在线互动教程:

2、示例代码:用web3dart生成以太坊地址

生成以太坊地址是绝大多数希望支持以太坊区块链的Flutter应用所需要的功能特性。
web3dart开发包使得这一过程相当简单明了:web3dart的crypto库提供了三个API函数,
分别用于生成私钥、从私钥推导出公钥、以及从公钥推导出以太坊地址:

首先我们引入必要的库:

import 'dart:math';                                     // Random
import 'dart:typed_data';                               // Uint8List     
import 'package:web3dart/crypto.dart';

STEP 1# 创建随机私钥

为此我们需要利用math库中的安全随机数发生器,然后调用crypto库中的generateNewPrivateKey()生成一个随机私钥:

Random rng = Random.secure();                            //安全随机数发生器
BigInt privKey = generateNewPrivateKey(rng);             //生成新的私钥

STEP 2# 从私钥推导出公钥

直接调用crypto库中privateKeyToPublic()函数,即可从指定的私钥推导出公钥:

Uint8List pubKey = privateKeyToPublic(privKey);          //从私钥推导出公钥      
print('public Key => ${bytesToHex(pubKey)}');            //显示其16进制字符串表示

bytesToHex()是crypto库提供的一个辅助API,用于将字节数组(Uint8List)转换为16进制表示的字符串。

STEP 3# 从公钥推导出地址

直接调用crypto库中publicKeyToAddress()方法,从指定的公钥码流推导出地址码流:

Uint8List address = publicKeyToAddress(pubKey);          //从公钥推导出地址
String addressHex = bytesToHex(
                      address,                           //地址字节数组
                      include0x:true,                    //包含0x前缀
                      forcePadLength:40                  //补齐到40字节
                    );
print('address => ${addressHex}');                       //显示地址

原文链接:Fluter/Dart生成以太坊地址 - 汇智网