怎么归集没有以太币的地址的ERC20代币?

在开发交易平台时一个常见的问题是:为用户生成的以太坊地址 没有以太币,那么怎么归集用户充进来的ERC20代币?能不能用一个 其他地址来代为支付这些ERC20代币的转账交易gas费?本文将解答这一问题。

1、问题场景

假设你的平台要支持50种ERC20代币,用户会向你的平台生成的以太坊 地址充值,然后你要归集这些平台地址上的代币到你的冷钱包。

问题:你为用户生成的平台充值地址上并没有以太币,因此就没有办法 直接用这个地址来调用ERC20代币的trasfer()方法进行归集。我知道 gas费用不能省掉,那么能不能使用其他账户为这些支付这些充值地址上 的ERC20代币的转账交易?

2、解决方案

简单说,无论如何你的代币充值地址需要有一定量的以太币来支付gas费用。 现有的ERC20标准也不支持以其他账户代付gas费。虽然目前已经有一些提议 从不同的角度尝试解决这一问题,但是都还没有形成标准。例如:

  • EIP 865:支持代理转账/delegatedTransfer,详见EIP 865
  • EIP 955:扩展了ERC777,增加了一个支票操作员/Cheque Operator,详见EIP 965

这些提议都要求代币合约的修改,因此对于已经存在的ERC20代币而言并没有 什么用。

因此显而易见的解决方案,就是向生成的地址发送足量的以太币来涵盖归集 代币所需要的gas成本。

3、交易所是怎么做的?

大部分的交易所(如果不是全部的话)采用如下的方案:

  • 生成充值地址
  • 向地址转入一定量的以太币用来覆盖几次代币转账的gas成本
  • 当用户超过一段时间不活跃后收回该地址上的以太币
  • 每个用户的所有ERC20代币使用同一充值地址

汇智网原创,转载请标明出处