ASS:如何玩转Bycoin钱包?这篇文章告诉你_RES

细心的用户可能发现Bycoin钱包在高级设置下面增加了几个新的功能——钱包余额刷新工具,UTXO合并工具,如下图:

这些小工具可以一键解决用户使用过程中的一些小问题,那么这些小工具有什么作用呢?

钱包余额刷新工具

钱包余额刷新工具可以强制节点再次更新用户账户的余额信息,解决合约转账或者余额未及时同步的问题。

外部账户和合约账户

我们知道以太坊中有两类账户——外部账户和合约账户

外部账户:该类账户被公钥-私钥对控制,外部账户的地址是由公钥决定的

合约账户:该类账户被存储在账户中的代码控制,合约账户的地址是在创建合约时确定的

两种账户都可以实现对以太币的管理,包括持有以太币、查询余额、发送交易等。

交易和内部交易

一般用户转账的时候,都是使用外部账户对代币合约发起调用,调用转账的方法,最终发起转账的请求到以太坊节点。

那么什么是内部交易,内部交易就是合约之间的调用,通过合约状态的改变从而达成转账的目的

Polychain Capital实习生展示如何使用100美元对CheapETH进行51%攻击:风险投资公司Polychain Capital的18岁实习生Anish Agnihotri展示了51%攻击的工作方式,以达到教育目的。Agnihotri选择了CheapETH来进行实验。为了发动攻击,Agnihotri租用了能够每秒执行14.4亿哈希的挖矿设备。这样一来,他就可以占据该网络哈希率的72%左右。此外,他还租用了虚拟机来运行区块链。总费用不到100美元。(The Block)[2021/5/18 22:12:59]

针对第一种普通转账,Bycoin可以很轻易检测到用户余额的改变,而内部交易较难检测到其内部的行为。所以通过钱包余额刷新工具来更新内部交易产生的交易而导致的余额变化。

钱包余额刷新工具做了什么?

钱包余额刷新工具会请求以太坊的节点,来重新查询用户的地址,获取内部交易产生的余额变动,并将查询结果记录到数据库中,从而将用户余额正确更新.

func(s*Service)SyncBalance(c*gin.Context)error{address,err:=formatETHAddress(c.Query("address"))iferr!=nil{returncommonTypes.ErrAddressFormat}iferr:=s.DB.Slave().Model(orm.Address{}).Where("address=?",address).First(&orm.Address{}).Error;err!=nil{returncommonTypes.ErrNotFoundAddress}ormAssets:=make(orm.Asset,0)iferr:=s.DB.Slave().Model(orm.Asset{}).Find(&ormAssets).Error;err!=nil{returncommonTypes.ErrAssetID}blockHeight,err:=s.node.GetBlockCount()iferr!=nil{returnerr}for_,asset:=rangeormAssets{ifasset.Asset==ETH{iferr:=ethereum.UpdateBalance(s.DB.Master(),address,s.node,asset.Asset,asset.ID,int64(blockHeight));err!=nil{returnerr}}else{iferr:=ethereum.UpdateBalance(s.DB.Master(),address,s.node,asset.ContractAddress,asset.ID,int64(blockHeight));err!=nil{returnerr}}}returnnil}funcUpdateBalance(db*gorm.DB,addressstring,node*Node,assetstring,assetIDuint64,blockHeightint64)error{......//UPDATE}else{//ERC20balancebalanceBigInt,decimal,err:=node.GetERC20Balance(address,asset)iferr!=nil{returnerr}......}addressInfo:=orm.Address{Address:address}iferr:=db.Select("id").Where("address=?",address).Find(&addressInfo).Error;err!=nil{errors.Wrap(err,"errselectaddress")returnnil}balance:=&orm.Balance{AddressID:addressInfo.ID,AssetID:assetID,Balance:value,PendingBalance:pendingValue,LastUpdateBlock:uint64(blockHeight),}returnsaveBalance(db,balance。

Craig Wright:PoW是指导网络存在分歧时如何行动的信号:Craig Wright在其最新的博客文章中解释了为什么工作量证明(Proof-of-Work,PoW)是至关重要的。他表示,工作量证明是一种重要的信号,它告诉网络上的节点,当网络上存在分歧时,该如何行动。重要的是要区分这些节点不是对网络规则投票,而是执行规则。他说,“工作量证明是一种经济信号,从理论上讲是从游戏的角度去激励玩家的诚实行为,或者提供一种惩罚机制。”[2020/8/20]

UTXO合并工具

很多朋友都遇到过UTXO太碎导致交易不成功的现象,Bycoin通过这款工具可以一键解决此类用户的问题。

什么是UTXO

UTXO是UnspentTransactionOutput的缩写,意思是未花费的输出,可以简单理解为还没有用掉的收款。UTXO核心设计思路是:它记录交易事件,而不记录最终状态。要计算某个用户有多少币,就要对其钱包里所有的UTXO求和,得到结果就是他的持币数量。

比原链和比特币一样,也是采用UTXO模型。

为什么需要UTXO合并

声音 | 奥斯汀市雇员退休制度CIO:应关注加密资产如何适应现有的投资组合:据coindesk消息,今日在彭博社举办的Institutional Crypto会议上,美国德州奥斯汀市雇员退休制度首席投资官(CIO)David Veal表示:“我不确定加密资产是否需要被定位为可替代资产,我们应该看看它如何适应现有的投资组合。加密资产可以通过使如此多事物获得流动性来消除非流动性。我们的投资组合多样化正慢慢受到侵蚀,而加密可以带来回报。”[2018/10/16]

我们看到UTXO模型中,任何一笔交易的输入都是前一笔交易的输出,然后当你的UTXO数量非常多时,你的交易会有很多的输入,从而整体的交易体积会变大,因为区块的容量有限制,为了防止有人恶意使用大量小的UTXO构建一笔体积非常大交易,从而出现堵塞区块的出现,比原链限制了输入UTXO的个数最大为20个,当你UTXO太多时,可能会出现交易不成功的现象,那么我们需要将UTXO合并工具,通过发送交易给自己,将小额的UTXO合并成大的UTXO。

UTXO合并工具做了什么?

UTXO合并工具首先判断是否有合并的余额,以及是否需要合并

balance,err:=coin.CalcBalance(s.DB.Slave(),account,req.Asset,req.Confirmation)iferr!=nil{returnnil,err}ifbalance.Cmp(big.NewInt(0).SetUint64(totalAmount))<0{returnnil,errors.Wrap(types.ErrInsufficientBalance,fmt.Sprintf("balance%sless%d",balance.String(),totalAmount)。然后会寻找该账户关联的所有的UTXO

Web3 基础设施协议 Ankr 将为 Optimism 提供 RPC 服务:6月16日消息,Web3 基础设施协议 Ankr 宣布将为 Optimism 提供 RPC(远程过程调用)服务。Ankr 表示,Ankr 将提供一个由许多在全球范围内运行的独立区块链节点组成的,地理上的分布式和去中心化的 Optimism RPC,以实现低延迟和可靠的连接。Ankr 还表示,将为 Optimism 开发者省去建立节点的工作、提供对高级工具的访问权限以及为需要访问 Optimism 的应用和开源软件提供支持等。[2022/6/16 4:30:45]

utxoFinder:=coin.NewUTXOFinderWithFindStrategy(s.DB.Slave(),ormCoin,account,builder.EstimateGas,builder.FindUTXOs)ifreq.SpendAll{optUTXOs,err=utxoFinder.PrepareAllUTXOs(req.Asset,req.Confirmation,s.Cfg.Coin.DesiredUtxoCount)iferr!=nil{returnnil,errors.Wrap(err,"prepareallutxos"。iflen(optUTXOs)==0{optUTXOs,_,err=utxoFinder.PrepareUTXOs(req.Asset,totalAmount,req.Confirmation,s.Cfg.Coin.DesiredUtxoCount)iferr!=nil{returnnil,errors.Wrap(err,"prepareUTXOs"。if!req.ForbidChainTx&&len(optUTXOs)>s.Cfg.Coin.ChainTxMinUTXONum&&(s.Cfg.Coin.ChainTxMergeGas==0||req.Asset==consensus.BTMAssetID.String()){chainUTXOs:=optUTXOsif!req.SpendAll{chainUTXOs,err=utxoFinder.PrepareChainUTXOs(req.Asset,totalAmount,req.Confirmation,s.Cfg.Coin.DesiredUtxoCount,s.Cfg.Coin.ChainTxMinUTXONum,s.Cfg.Coin.ChainTxMergeGas)iferr!=nil{returnnil,errors.Wrap(err,"preparechainutxos"。最后通过链式交易进行合并。

声音 | 救助儿童会Paul Ronalds:慈善机构领导者也应去了解区块链等技术如何运作:根据Coincryptorama消息,救助儿童会首席执行官Paul Ronalds在关于区块链对慈善事业的潜在影响的小组讨论后表示,慈善机构对区块链的使用还处于初期阶段”,要在其潜力被夸大之前需要进行更多的讨论和研究。慈善机构面临的主要障碍之一是,当涉及区块链这种存储数据的方法时,行业领导者并不能很好理解,我们需要确保慈善机构领导者同样参与、了解数字世界以及如何运作区块链等技术,来帮助他们的做好慈善事业。[2018/9/3]

chainTxs,utxos,err:=builder.BuildChain(s.TxDecoder,chainUTXOs,req.Asset,s.NetParams,s.Cfg.Coin.ChainTxMinUTXONum,s.Cfg.Coin.ChainTxMergeGas)iferr!=nil{returnnil,errors.New("buildtxchain"。for_,chainTx:=rangechainTxs{resp,err:=s.createBuildPaymentResp(account,chainTx.OptUtxos,chainTx.Fee,chainTx.Tx,chainTx.SigningInstructions,"")iferr!=nil{returnnil,err}result=append(result,resp。optUTXOs=utxos}fee:=builder.EstimateGas(len(optUTXOs),account.M(),account.N())resp,err:=s.buildPaymentWithUTXO(req,req.Asset,ormCoin,account,optUTXOs,fee,builder)iferr!=nil{returnnil,errors.Wrap(err,"buildpayment"。returnappend(result,resp),nil}

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

区块博客

[0:0ms0-6:65ms