usdt转入转出出入金开发

比特币协议 -> Omni 层协议 -> USDT
USDT是基于比特币omni协议的一种代币: https://omniexplorer.info/asset/31 ID是31

Tether(USDT 的发行方)的官方钱包已关闭注册,无法注册钱包就无法获得 API Key,也就意味着无法实现类似基于钱包接口的开发方案,但我们可以基于 USDT 的底层协议(叫做 Omni 层协议)进行开发

USDT 的协议结构从底层到顶层大致是:「比特币协议 -> Omni 层协议 -> USDT」,也就是说,USDT 是基于比特币的一种代币(token);
另外USDT也出了最新的以太坊(ERC20 标准)版本,但发行量和流通量都太小,所以还是基于比特币 Omni 层协议的经典USDT。

可以安装并运行一个 Omni Core 节点客户端,然后利用其提供的 RPC 接口,实现我们 USDT 出入金所需的代币发送、接收等功能。

调用时http响应时间默认设置3秒超时会失败,实际已转出成功,需要改成10秒或更长后才可以正常接收到返回状态。

usdt基于btc的,所以钱包里转入转出都需要通过比特币链上操作都需要btc手续费,这也是很多交易所有最低充值额度的限制的原因。

=========================
usdt有单独节点,一般是用bitcond源码搭建的
如果自己搭建了节点看下面这个文档就可以搞定了
怎么搭建节点,github上有的。
https://github.com/OmniLayer/omnicore/blob/master/src/omnicore/doc/rpc-api.md#omni_send
这个是usdt rpc调用提供的命令文档。

自己不搭建节点需要另外开发?
自己不搭建节点就需要依赖三方平台,这样不安全。

==================

importprivkey 出金之前需要把 address and privKey import to node
call rpc : importprivkey pls
usdt node 提供的命令。
文档上有说明。

importprivkey 就是个rpc命令,你call下就可以了,参数就是address和privKey, 也许你们node不需要,
如果你刚才出金成功了,就ok,没有成功,就call importprivkey 下

Usdt 出金 是个from to的形式,如果出金地址固定,就不用知道from, to是必须要指定的。
deposit: 扫描区块,如果发现 to

to地址如果是存在你们的db中,就需要处理deposit的数据。
deposit 指的是入金。
扫描区块的时候,blocknumber->blockHash->txHash->tx Details.
其中details就是json字符串,里面就有from to的地址,然后判断to地址是否存在db中,说明别的平台向你们平的to地址有入金。

出金: 平台必须有个出金总地址addr,所有的出金都是从addr扣取。
扫描区块的时候,blocknumber->blockHash->txHash->tx Details. 其中details就是json字符串,里面就有from to的地址,然后判断to地址是否存在db中,说明别的平台向你们平的to地址有入金。

入金是要扫描区块的,去分析交易详情,发现有个to地址,要判断这个to地址是不是你们平台的,如果是的,说明这次交易就是你们自己平台的地址在入金,所以这个交易详情需要入库。

中心钱包按照一定的百分比条件转钱给冷钱包。 如果出金总地址余额不够了,就要从热钱包转账给出金总地址。
现金流监控有个策略的。

转账上链就必须要扣除手续费, to地址有N多个,你要写个算法以最少的手续费转给冷钱包。
中心钱包, 出金钱包, 热钱包, 冷钱包 四个钱包按照策略比例相互转。先要把这四个钱包概念弄清楚。

要分平台内出金还是平台外,平台外出金上链扣手续费,平台内直接划账
地址存db, 没有导入到钱包,实现方式可以不一样

用户地址对应公链上的余额是转到冷钱包地址
用户看到的余额是用户账号对应db中的余额,用户地址对应公链的余额用户没有实际的转账权限,不能到外部平台转账,只能在自己平台转账。
就是像中心钱包到了,钱包冷,钱包之间相互转,这个你是必须要上链的,上链要手续费,这个余额是钱包的余额。
如果是平台内转账,那是你这个平台内的。一个是钱包的余额。一个是一个用户在你这个平台申请个账号,你给他分配的余额,这是两个不同的余额。
子钱包充值进来的都是链上的余额转账都需要通过链上,需要手续费。比特币的最佳手续费有第三方api接口可以动态获取。
usdt钱包里的币要转出到大钱包需要先转点btc进去做手续费才能转账,转多少进去合适需要看代码和策略。

-------------------------
交易所,要出金的时候,importprivkey, 出金完了,能把privkey删除掉吗?
其他币种也是这么操作的?像ETH用什么RPC ?

只有usdt需要import
eth使用web3j组件就可以了

那BTC的处理,和USDT一样吧?

不需要删除

不删除,那不就成了热钱包了吗?

btc用的是bitcoinj
importprivkey 只是node提供的rpc命令,

并不会把privkey存储到wallet.dat中? 命令执行完, 就会自动删除?
下次执行,还需要import ?

import一次就可以了

跟自己直接在node上创建的账户差不多
你们只是在另外一个node 或者工具上创建了账号,并保存在数据库中,真正要转账时,把它import到节点上
这不是真正的离线签名吧?

就是你说的这样
离线签名是先算出交易签名,然后再广播出去
地址这块你们实现跟我实现的不一样,我用的是地址派生,根据userid派生
只有usdt在创建地址的时候会import到node

usdt转入转出出入金开发的更多相关文章

  1. usdt钱包开发,比特币协议 Omni 层协议 USDT

    usdt钱包开发 比特币协议 -> Omni 层协议 -> USDT USDT是基于比特币omni协议的一种代币: https://omniexplorer.info/asset/31 I ...

  2. EAGO科技人工智能+澳洲MSPL外汇平台招商

    天下财经 首席运营商 EAGO外汇人工智能简介:我们将历史数据导入算法引擎,加入因子(外汇中使用的各种技术指标及各个国家的货币政策等)让计算机通过二元遗传基因.深度神经网络等算法,由机器自主深度学习. ...

  3. 算法型稳定币USDN是如何保持稳定的?

    数据显示,2019年稳定币市场总市值25亿美元,在整个加密货币市场占比 1.3%.可别小瞧了看似微小的1.3%这个数据,它其实是一个庞大的市场.稳定币不仅仅是货币的电子化,它还是一种可编程的加密货币, ...

  4. AngularJS +HTML Demo

    <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="C ...

  5. WPF+通过配置文件生成菜单(Menu)+源码

    这个月做项目,遇到过一个通过配置文件来生成菜单的解决方案,感觉挺优雅的,特地放到博客园来,以飨读者. 说来惭愧,以前做的项目都没有这样用过,都是固定死了.如果后续有需要加入菜单,还得在重新修改UI,然 ...

  6. j2ee分布式缓存同步实现方案dlcache v1.0.0

    现成的分布式K/V缓存已经有很多的实现,最主要的比如redis,memcached,couchbase.那为什么我们还要自己去实现呢,在我们解决了分布式系统下大量rpc调用导致的高延时后,我们发现很多 ...

  7. 2016iweb峰会参会总结

    2016年8月27日去国家会议中心参加iweb峰会. 8点半开始签到入场,8点20分排队签到的人已经排到另一个门口,人超级多啊. 9点一如既往的由h5女神娜姐开场. 上午场 基本是各公司的大佬们介绍各 ...

  8. j2ee分布式缓存同步实现方案dlcache

    现成的分布式K/V缓存已经有很多的实现,最主要的比如redis,memcached,couchbase.那为什么我们还要自己去实现呢,在我们解决了分布式系统下大量rpc调用导致的高延时后,我们发现很多 ...

  9. AJPFX的资金安全性

    AJPFX承诺保证客户资金安全,并严格按照英国的相关规章制度从事经营活动.客户资金存放于投资级银行的独立账户中.通过实行公司资产与客户资金分别保管,在发生无偿债能力的罕见情况下,客户可获退还独立存放资 ...

随机推荐

  1. Linux dmidecode 命令

    当我们需要获取机器硬件信息时,可使用linux系统自带的dmidecode工具进行查询. dmidecode 用于获取服务器的硬件信息,通常是在不打开计算机机箱的情况下使用该命令来查找硬件详细信息 这 ...

  2. 各大知名区块链交易所链接及API文档链接

    区块链交易所链接 火币网(Huobi):https://www.huobi.br.com/zh-cn/ API文档:https://github.com/huobiapi/API_Docs/wiki ...

  3. mysql跨库复制: replicate_wild_do_table和replicate-wild-ignore-table

    使用replicate_do_db和replicate_ignore_db时有一个隐患,跨库更新时会出错. 如设置 replicate_do_db=testuse mysql;update test. ...

  4. git基础知识

    Git的两大功能 1.协作开发 2.版本控制 版本库 版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改.删除,Git都 ...

  5. 008-ThreadLocal原理分析

    一.简介 早在JDK 1.2的版本中就提供java.lang.ThreadLocal,ThreadLocal为解决多线程程序的并发问题提供了一种新的思路.使用这个工具类可以很简洁地编写出优美的多线程程 ...

  6. AxMIMS系统开发环境搭建

    系统环境:Windows10, VS2013, Qt5.6.2 64bit 1.CloudCompare2.8.1编译 (shapefilelib1.3,geos3.6.1) 2.PCL-1.8.0- ...

  7. Java实现个人博客网站

    说明:该项目是实验楼用户"LOU3165780622"发布在实验楼上的项目教程:[Java实现个人博客],未经允许,禁止转载: 该项目利用 SSM 框架和 Mysql 以及一些简单 ...

  8. jenkins 常见问题汇总

    1.jenkins api调用 https://my.oschina.net/sanpeterguo/blog/197931 其中,有个错误的地方,带参数构建时,使用的时POST方法,如下: curl ...

  9. [LeetCode] 129. Sum Root to Leaf Numbers_Medium tag: DFS

    Given a binary tree containing digits from 0-9 only, each root-to-leaf path could represent a number ...

  10. 带上RESTful的金手铐,你累吗?

    1. 首先RESTful是一套规范,不是框架,它是来约束你的.也不关心生产效率的提高.就好像使用汇编开发应用,性能是快了,但是生产效率很低.RESTful它需要你在路由上定义很多规则来解释的URL,假 ...