之前想用React Native开发一版以太坊钱包app,但在生成账户那块遇见了问题,没有crypto等nodejs包,react native是运行在JavaScriptCore环境里面,是没有buffer, crypto 跟 stream这些库的,所以为了解决,就跟同事开发了基于golang的web3go,然后使用gomoble工具编译成ios需要的framework以及android需要的jar aar,完美解决问题
演示
dapp-demo-1.jpg
dapp-demo-2.jpg
安装web3go
git clone https://github.com/bcl-chain/web3.go.git
使用gomobile编译成framework,jar,aar
// generate frameworkgomobile bind -target=ios ./github.com/bcl-chain/web3 .go/mobile// generate arr jargomobile bind -target=android ./github.com/bcl-chain/web3.go/mobile
把生成的包link到原生app里面
link-web3go.jpg
andoir-getbalence.jpg
下载ETH本地测试工具ganache-cli
gan-cli.jpg
安装依赖
yarn react-native run-android react-native run-ios
getBalance代码分析
// IOS RCT_EXPORT_METHOD(getBalance: (NSString*) address: (RCTPromiseResolveBlock)resolve rejecter:(RCTPromiseRejectBlock)reject){ // ip地址 Web3goEthereumClient* client = Web3goNewEthereumClient(nodeIP, nil); Web3goContext* ctx = Web3goNewContext(); // 账户地址 Web3goAddress* address1 = Web3goNewAddressFromHex(address, nil); @try { Web3goBigInt* a = [client getBalanceAt:ctx account:address1 number:-1 error:nil]; NSString* ammount = [a getString:10]; NSLog(@"%@", ammount); resolve(ammount); } @catch (NSError *exception) { NSLog(@"NSError: %@", exception); reject(@"NSError: %@", @"There were no events", exception); } @finally { NSLog(@"finally"); } } // android @ReactMethod public void getBalance(String address, Promise promise) { try { web3go.EthereumClient client = Web3go.newEthereumClient(nodeIP); web3go.Context ctx = Web3go.newContext(); web3go.Address address1 = Web3go.newAddressFromHex(address); web3go.BigInt a = client.getBalanceAt(ctx, address1, -1); String ammout = a.getString(10); promise.resolve(ammout); } catch (Exception e) { promise.reject(e.getMessage()); } } // react-native async getBalance() { try { var ammount = await NativeModules.Web3go.getBalance(this.state.defGaAddress); this.setState({ gaAmmount: ammount }) } catch (e) { console.error(e); } }
如果有用,给个start
web3go
React-Native-Dapp
总结
以上所述是小编给大家介绍的使用React Native创建以太坊钱包实现转账等功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]