[发明专利]一种基于UTXO模型区块链智能合约的资产交换方法有效
申请号: | 201910471846.6 | 申请日: | 2019-05-31 |
公开(公告)号: | CN110222120B | 公开(公告)日: | 2021-04-09 |
发明(设计)人: | 阳胜;张成成;朱益祺 | 申请(专利权)人: | 杭州时戳信息科技有限公司 |
主分类号: | G06F16/27 | 分类号: | G06F16/27;G06Q40/04 |
代理公司: | 浙江永鼎律师事务所 33233 | 代理人: | 郭小丽 |
地址: | 310000 浙江省杭*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 utxo 模型 区块 智能 合约 资产 交换 方法 | ||
本发明公开了一种基于UTXO模型区块链智能合约的资产交换方法,包括以下步骤:构建智能合约;发送者将指定数量的资产锁定到智能合约之中,完成对发送者的资产转移;若接收者解锁智能合约,按照智能合约规定的条件,将指定数量的资产发送到发送者的地址,并且通过验证,接收者获取智能合约中发送者锁定的资产,同时发送者也获得接收者交换的资产;若始终没有接收者去解锁智能合约时,发送者通过预先设置的验证自我的方式解锁合约,将智能合约锁定的资产返还给自己。本发明便捷地实现各种类型的资产交换场景,其实质是对交易的输出状态进行验证,其验证包括交易输出资产类型、资产数量、资产类型和接收地址等,提高了交易的效率、安全性和可靠性。
技术领域
本发明属于区块链技术领域,具体涉及一种基于UTXO模型区块链智能合约的资产交换方法。
背景技术
区块链技术是一种去中心化的分布式数据库技术,运用区块链技术可以实现公开透明、可信任的去中心化交易,不仅包括用户之间的普通转账交易,还包括多用户参与的特殊资产交换交易(即合约交易)等场景。
当前基于UTXO模型的区块链有比特币、莱特币、比特币电子现金等,他们都是无状态的、单一资产的区块链,并且虚拟机都是非图灵完备的,难以实现复杂的智能合约。与此同时,像以太坊、EOS等基于账户模型的区块链的虚拟机是图灵完备的,但是他们的智能合约执行结果存在不可预测性,可能会导致严重的安全问题。而基于UTXO模型的多资产模型的区块链,原生支持多资产类型,由于它们都存储于轻量级的未花费的交易输出中,执行的结果状态是可预测的,那么如果在这种模型的链上实现安全的资产交互(例如币币交易、抵押贷款、看涨期权和去中心化交易所等),不仅可以扩展UTXO模型区块链的应用场景,而且还可以大大提升交易的效率和安全性,因此如何利用合约交易实现用户之间的资产交互场景是一个重要的课题。
发明内容
为了解决上述问题,本发明提供了一种基于UTXO模型区块链智能合约的资产交换方法,提升交易的效率和安全性。
本发明的技术方案为:一种基于UTXO模型区块链智能合约的资产交换方法,包括以下步骤:
S1:构建智能合约;
S2:发送者将指定数量的资产锁定到智能合约之中,完成对发送者的资产转移;
S3:若接收者解锁智能合约,按照智能合约规定的条件,将指定数量的资产发送到发送者的地址,并且通过验证,接收者获取智能合约中发送者锁定的资产,同时发送者也获得接收者交换的资产;
若始终没有接收者去解锁智能合约时,发送者通过预先设置的验证自我的方式解锁合约,将智能合约锁定的资产返还给自己。
作为优选,所述步骤S1中,资产交互的双方或多方将协商的内容和规则写入到区块链的智能合约中,构建智能合约。
作为优选,资产交互的任意一方均可作为合约的发起人,将自己需要兑换的资产数量和资产类型锁定在智能合约之中,以供交易的另一方或多方进行调用,并且资产交互的智能合约会对交易的输出内容进行验证。
作为优选,发送者通过预先设置的单签、多签或谜语的方式验证自我的方式解锁合约,将智能合约锁定的资产返还给自己。
作为优选,若发送者需要修改定价时,所述发送者通过验证调用修改定价,并将修改定价之后的资产继续锁定在智能合约之中。
作为优选,区块链的虚拟机指令集包含交易输出校验、资产类型状态以及资产数量状态相关的指令。
作为优选,协商的交易双方可以在合约内容中添加规则校验,提高合约交易的安全性。
作为优选,所述规则校验包括时间范围和/或安全性签名。
与现有技术相比,本发明的有益效果体现在:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州时戳信息科技有限公司,未经杭州时戳信息科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910471846.6/2.html,转载请声明来源钻瓜专利网。