[发明专利]基于智能合约的隐私数据查询方法及装置有效
申请号: | 201911085017.0 | 申请日: | 2019-11-08 |
公开(公告)号: | CN110580417B | 公开(公告)日: | 2020-04-07 |
发明(设计)人: | 刘琦;闫莺;宋旭阳 | 申请(专利权)人: | 支付宝(杭州)信息技术有限公司 |
主分类号: | G06F21/62 | 分类号: | G06F21/62;G06F16/2458;G06Q40/04 |
代理公司: | 北京博思佳知识产权代理有限公司 11415 | 代理人: | 李威 |
地址: | 310000 浙江省杭州市*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 基于 智能 合约 隐私 数据 查询 方法 装置 | ||
1.一种基于智能合约的隐私数据查询方法,应用于区块链节点;所述方法包括:
当接收到查询方发起的针对目标隐私数据的查询交易时,读取所述查询交易中包含的与所述目标隐私数据相关的历史交易的交易标识和所述历史交易调用的业务合约的合约地址;其中,所述历史交易通过调用所述业务合约以执行所述业务合约中定义的业务代码;
根据所述合约地址获取所述业务合约,并执行所述业务合约中定义的权限控制代码,以确定所述查询方针对所述目标隐私数据的查询权限;
在确定查询权限为允许查询后,根据所述交易标识获取所述历史交易,根据获取到的历史交易确定出所述历史交易实际调用的业务合约的合约地址;当确定出的合约地址与所述查询交易中包含的所述历史交易调用的业务合约的合约地址不一致时,禁止执行获取所述目标隐私数据的操作;
当确定出的合约地址与所述查询交易中包含的所述历史交易调用的业务合约的合约地址一致时,根据所述交易标识获取所述目标隐私数据并将获取到的目标隐私数据读入可信执行环境进行解密,以由所述查询方获取。
2.根据权利要求1所述的方法,还包括:
当接收到的任一交易用于调用分发合约时,将所述任一交易作为所述查询交易;
执行所述分发合约中定义的分发代码,以根据所述合约地址调用所述业务合约执行所述权限控制代码。
3.根据权利要求1所述的方法,所述目标隐私数据包括以下至少之一:
所述历史交易、对应于所述历史交易的交易收据、所述历史交易的发起方的账户属性信息、所述业务合约的账户属性信息、所述业务合约的合约代码、所述业务合约的合约状态数据。
4.根据权利要求3所述的方法,所述目标隐私数据包括所述历史交易和/或所述交易收据;所述将获取到的目标隐私数据读入可信执行环境进行解密,包括:
获取所述历史交易的发起方使用的对称密钥;
在所述可信执行环境内通过所述对称密钥对所述目标隐私数据进行解密。
5.根据权利要求4所述的方法,所述获取所述历史交易的发起方使用的对称密钥,包括:
获取用于加密所述历史交易的对称密钥,所述对称密钥被所述历史交易的发起方使用的公钥加密;
在所述可信执行环境内通过与所述历史交易的发起方使用的公钥对应的私钥,对所述对称密钥进行解密以得到解密后的对称密钥。
6.根据权利要求5所述的方法,所述历史交易的发起方使用的公钥由密钥管理服务器通过远程证明发送至所述历史交易的发起方,所述区块链节点的可信执行环境由SGX架构建立,与所述公钥对应的私钥由所述密钥管理服务器通过远程证明发送至所述区块链节点的围圈。
7.根据权利要求3所述的方法,所述目标隐私数据包括所述历史交易的发起方的账户属性信息、所述业务合约的账户属性信息、所述业务合约的合约代码、所述业务合约的合约状态数据中至少之一;所述将获取到的目标隐私数据读入可信执行环境进行解密,包括:
在所述可信执行环境内通过所述区块链节点的对称密钥对所述目标隐私数据进行解密。
8.根据权利要求7所述的方法,所述区块链节点的可信执行环境由SGX架构建立,所述对称密钥在所述区块链节点的SGX架构通过远程证明后由密钥管理服务器发送,或者由所述区块链节点与其他区块链节点之间进行协商得到。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于支付宝(杭州)信息技术有限公司,未经支付宝(杭州)信息技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201911085017.0/1.html,转载请声明来源钻瓜专利网。