以太坊生成地址_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_tutorialdependencies: web3dart:  git: git://github.com/simolus3/web3dart.git

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

~/hubwiz_tutorial$ pub get

如果希望快速掌握Flutter / Dart应用对接以太坊区块链的方法,推荐 汇智网的在线互动教程《Flutter以太坊开发详解》,访问地址:http://xc.hubwiz.com/course/5d0f51ba574541f94050cf4e?affid=tt7878

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

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

以太坊生成地址_Flutter / Dart 生成以太坊地址_第1张图片

首先我们引入必要的库:

import 'dart:math'; // Randomimport '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生成以太坊地址 - 汇智网

你可能感兴趣的:(以太坊生成地址)