[发明专利]一种数据存储的方法、装置及设备在审
申请号: | 201810159643.9 | 申请日: | 2018-02-26 |
公开(公告)号: | CN108537063A | 公开(公告)日: | 2018-09-14 |
发明(设计)人: | 陈忻 | 申请(专利权)人: | 阿里巴巴集团控股有限公司 |
主分类号: | G06F21/64 | 分类号: | G06F21/64;H04L29/06 |
代理公司: | 北京晋德允升知识产权代理有限公司 11623 | 代理人: | 杨移 |
地址: | 英属开曼群岛大开*** | 国省代码: | 开曼群岛;KY |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 区块 链节点 主节点 存储 数据共享请求 装置及设备 数据存储 块链 网络 验证 共享数据 写入 | ||
1.一种数据存储的方法,共识网络由多个区块链节点构成,所述区块链节点包含主节点和从节点,所述方法包括:
区块链节点接收数据共享请求;
根据所述数据共享请求中包含的待共享数据,生成区块;
若所述区块链节点为主节点,将所述区块添加到自身存储的区块链中,并将所述区块发送给所述共识网络中的其他区块链节点进行存储;
若所述区块链节点为从节点,将所述区块发送给所述共识网络中的主节点进行验证,以使所述主节点在对所述区块通过验证后,将所述区块添加到所述主节点自身存储的区块链中,并将所述区块发送给其他区块链节点进行存储。
2.如权利要求1所述的方法,根据所述数据共享请求中包含的待共享数据,生成区块,具体包括:
根据所述数据共享请求中包含的数据标识,查询所述待共享数据对应的原始数据;
确定所述原始数据变更为所述待共享数据的数据变更参数;
根据所述数据变更参数,生成所述区块。
3.如权利要求1所述的方法,若所述区块链节点为主节点,将所述区块发送给共识网络中的其他区块链节点进行存储,具体包括:
采用安全套接层SSL协议,将所述区块发送给所述共识网络中的其他区块链节点存储;
若所述区块链节点为从节点,将所述区块发送给所述共识网络中的主节点进行验证,具体包括:
采用安全套接层SSL协议,将所述区块发送给所述共识网络中的主节点进行验证。
4.如权利要求1所述的方法,若所述区块链节点为主节点,所述方法还包括:
当接收到其他区块链节点发送的至少两个特殊区块时,根据预设的规则,对所述至少两个特殊区块进行排序,所述至少两个特殊区块中包含有相同的上一区块的头哈希值;
针对除排在首位的每个特殊区块,将该特殊区块中包含的上一区块的头哈希值变更为排在前一个的特殊区块的头哈希值;
根据变更后的上一区块的头哈希值,更新该特殊区块对应的头哈希值;
将各特殊区块添加到自身存储的区块链中。
5.如权利要求4所述的方法,根据预设的规则,对所述至少两个特殊区块进行排序,具体包括:
根据所述至少两个特殊区块中包含的区块生成时间和/或各特殊区块对应的头哈希值,对所述至少两个特殊区块进行排序。
6.如权利要求1所述的方法,一个区块链节点至少向一个数据平台提供数据存储和数据查询服务;
区块链节点接收数据共享请求,具体包括:
接收与所述区块链节点对应的数据平台发送的数据共享请求;
所述方法还包括:
接收与所述区块链节点对应的数据平台的数据查询请求;
从所述区块链节点存储的区块链中查询所述数据查询请求对应的共享数据,并将所述共享数据返回给所述数据平台。
7.一种数据存储的装置,共识网络由多个区块链节点构成,所述区块链节点包含主节点和从节点,所述装置包括:
接收模块,接收数据共享请求;
生成模块,根据所述数据共享请求中包含的待共享数据,生成区块;
存储模块,若所述装置为主节点,将所述区块添加到自身存储的区块链中,并将所述区块发送给所述共识网络中的其他区块链节点进行存储;若所述装置为从节点,将所述区块发送给所述共识网络中的主节点进行验证,以使所述主节点在对所述区块通过验证后,将所述区块添加到所述主节点自身存储的区块链中,并将所述区块发送给其他区块链节点进行存储。
8.如权利要求7所述的装置,所述生成模块,根据所述数据共享请求中包含的数据标识,查询所述待共享数据对应的原始数据;确定所述原始数据变更为所述待共享数据的数据变更参数;根据所述数据变更参数,生成所述区块。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于阿里巴巴集团控股有限公司,未经阿里巴巴集团控股有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810159643.9/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种数据库数据动态加密的方法
- 下一篇:一种基于校验码的静态页面防篡改方法