CN109102209A - 一种基于区块链的商品配送方法及其系统 - Google Patents
一种基于区块链的商品配送方法及其系统 Download PDFInfo
- Publication number
- CN109102209A CN109102209A CN201811033491.4A CN201811033491A CN109102209A CN 109102209 A CN109102209 A CN 109102209A CN 201811033491 A CN201811033491 A CN 201811033491A CN 109102209 A CN109102209 A CN 109102209A
- Authority
- CN
- China
- Prior art keywords
- node
- dispatching personnel
- agent node
- payment code
- request
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/06—Resources, workflows, human or project management; Enterprise or organisation planning; Enterprise or organisation modelling
- G06Q10/063—Operations research, analysis or management
- G06Q10/0631—Resource planning, allocation, distributing or scheduling for enterprises or organisations
- G06Q10/06311—Scheduling, planning or task assignment for a person or group
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/08—Logistics, e.g. warehousing, loading or distribution; Inventory or stock management
- G06Q10/083—Shipping
Landscapes
- Business, Economics & Management (AREA)
- Human Resources & Organizations (AREA)
- Engineering & Computer Science (AREA)
- Economics (AREA)
- Strategic Management (AREA)
- Entrepreneurship & Innovation (AREA)
- Quality & Reliability (AREA)
- Development Economics (AREA)
- Marketing (AREA)
- Operations Research (AREA)
- Tourism & Hospitality (AREA)
- Physics & Mathematics (AREA)
- General Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Game Theory and Decision Science (AREA)
- Educational Administration (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本发明涉及区块链技术领域,特别是涉及一种基于区块链的商品配送方法及其系统。方法包括:普通节点向代理节点发送外卖下单请求;代理节点根据外卖下单请求,执行智能合约,以产生支付码,并向智能合约预留的节点地址对应的节点服务器发送所述外卖下单请求与支付码,支付码包括商品信息;普通节点向代理节点发送抢单请求;代理节点根据抢单请求,执行智能合约,以确定目标配送人员的身份信息,并向普通节点发送目标配送人员的身份信息以及支付码;节点服务器建立外卖下单请求、支付码及目标配送人员的身份信息之间映射关系的下单列表。由于区块链具有不可篡改、去中心化及高度透明化的特点,因此,其能够提供公平配送外卖的平台。
Description
技术领域
本发明涉及区块链技术领域,特别是涉及一种基于区块链的商品配送方法及其系统。
背景技术
区块链技术集合演算法、数学、密码学与经济模型等技术,基于点对点网路关系,建立信任机制,成为一个不需基于彼此信任基础、也不需依赖单一中心化机构便能够运作的分散式系统。因此,区块链技术能够广泛应用于各个行业领域,诸如无人商店等等行业领域,例如,区块链技术与外卖配送结合。
传统外卖平台由特定公司全权运营与维护,配送外卖人员时,其公开性与透明化程度不够高,配送人员以及消费者利益难以得到有效地维护。
发明内容
本发明实施例一个目的旨在提供一种基于区块链的商品配送方法及其系统,其能够提供公平配送外卖的平台。
为解决上述技术问题,本发明实施例提供以下技术方案:
在第一方面,本发明实施例提供一种基于区块链的商品配送方法,所述方法包括:
普通节点向代理节点发送外卖下单请求;
所述代理节点根据所述外卖下单请求,执行智能合约,以产生支付码,并向所述智能合约预留的节点地址对应的节点服务器发送所述外卖下单请求与所述支付码,所述支付码包括商品信息;
所述普通节点向所述代理节点发送抢单请求;
所述代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,并向所述普通节点发送所述目标配送人员的身份信息以及所述支付码;
所述节点服务器建立所述外卖下单请求、所述支付码及所述目标配送人员的身份信息之间映射关系的下单列表;
所述普通节点在检测所述支付码为合法支付码时,根据所述支付码的商品信息,自动取出与所述商品信息对应的商品,并向所述代理节点发送取单成功请求;
所述代理节点根据所述取单成功请求,从所述节点服务器中获取所述下单列表,并生成包含所述下单列表的区块数据。
可选地,所述代理节点存储有信用列表,所述信用列表包括每个配送人员的身份信息与信用分数,所述抢单请求携带有配送人员的地理位置,所述外卖下单请求携带有外卖地址;
所述代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,包括:
所述代理节点根据所述抢单请求,执行所述智能合约,以获取所述信用列表,并根据所述信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息。
可选地,所述代理节点根据所述信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息,包括:
所述代理节点根据公式:y=-2.5x+10+M,计算出每个配送人员总得分,其中,y为每个配送人员总得分,x为配送人员的地理位置与外卖地址之间的相对距离,M为配送人员的信用分数;
所述代理节点确定总得分最高的配送人员作为目标配送人员,并得到所述目标配送人员的身份信息。
可选地,所述x的取值范围为0-4。
可选地,生成包含所述下单列表的区块数据后,所述方法还包括:
所述代理节点向共识节点发送所述区块数据,以使所述共识节点共识验证所述区块数据。
在第二方面,本发明实施例提供一种基于区块链的商品配送系统,所述系统包括:若干普通节点及代理节点;
普通节点向代理节点发送外卖下单请求;
所述代理节点根据所述外卖下单请求,执行智能合约,以产生支付码,并向所述智能合约预留的节点地址对应的节点服务器发送所述外卖下单请求与所述支付码,所述支付码包括商品信息;
所述普通节点向所述代理节点发送抢单请求;
所述代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,并向所述普通节点发送所述目标配送人员的身份信息以及所述支付码;
所述节点服务器建立所述外卖下单请求、所述支付码及所述目标配送人员的身份信息之间映射关系的下单列表;
所述普通节点在检测所述支付码为合法支付码时,根据所述支付码的商品信息,自动取出与所述商品信息对应的商品,并向所述代理节点发送取单成功请求;
所述代理节点根据所述取单成功请求,从所述节点服务器中获取所述下单列表,并生成包含所述下单列表的区块数据。
可选地,所述代理节点存储有信用列表,所述信用列表包括每个配送人员的身份信息与信用分数,所述抢单请求携带有配送人员的地理位置,所述外卖下单请求携带有外卖地址;
所述代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,包括:
所述代理节点根据所述抢单请求,执行所述智能合约,以获取所述信用列表,并根据所述信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息。
可选地,所述代理节点根据所述信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息,包括:
所述代理节点根据公式:y=-2.5x+10+M,计算出每个配送人员总得分,其中,y为每个配送人员总得分,x为配送人员的地理位置与外卖地址之间的相对距离,M为配送人员的信用分数;
所述代理节点确定总得分最高的配送人员作为目标配送人员,并得到所述目标配送人员的身份信息。
可选地,所述x的取值范围为0-4。
可选地,生成包含所述下单列表的区块数据后,所述代理节点向共识节点发送所述区块数据,以使所述共识节点共识验证所述区块数据。
在本发明各个实施例提供的基于区块链的商品配送方法及其系统中,普通节点向代理节点发送外卖下单请求;代理节点根据所述外卖下单请求,执行智能合约,以产生支付码,并向智能合约预留的节点地址对应的节点服务器发送外卖下单请求与支付码,支付码包括商品信息;普通节点向代理节点发送抢单请求;代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,并向普通节点发送目标配送人员的身份信息以及支付码;节点服务器建立外卖下单请求、支付码及所述目标配送人员的身份信息之间映射关系的下单列表;普通节点在检测支付码为合法支付码时,根据支付码的商品信息,自动取出与商品信息对应的商品,并向代理节点发送取单成功请求;代理节点根据所述取单成功请求,从节点服务器中获取所述下单列表,并生成包含下单列表的区块数据。由于区块链具有不可篡改、去中心化及高度透明化的特点,因此,其能够提供公平配送外卖的平台。
附图说明
一个或多个实施例通过与之对应的附图中的图片进行示例性说明,这些示例性说明并不构成对实施例的限定,附图中具有相同参考数字标号的元件表示为类似的元件,除非有特别申明,附图中的图不构成比例限制。
图1是本发明实施例提供一种区块链网络的架构模型示意图;
图2是本发明实施例提供一种区块链系统的结构示意图;
图3是本发明实施例提供一种无人商店的结构示意图;
图3a是本发明实施例提供一种无人商店的电路原理示意图;
图4是本发明实施例提供一种基于区块链的商品配送方法的流程示意图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅用以解释本发明,并不用于限定本发明。
区块链技术亦称为分布式账本技术,是一种分布式互联网数据库技术。基于区块链技术构建的网络可以称之为区块链网络,区块链网络包含多个区块链节点,每一个节点对应至少一个区块链,每一个区块链上至少包含一个区块。区块链技术具备去中心化、公开透明、不可篡改、可信任等特点,因此,区块链技术应用领域越来越广泛。
请参阅图1,图1是本发明实施例提供一种区块链网络的架构模型示意图。如图1所示,该区块链网络100包括数据层11、网络层12、共识层13以及智能合约层14。
数据层11封装了底层数据区块以及相关的数据加密和时间戳等基础数据和基本算法。网络层12包括分布式组网机制、数据传播机制和数据验证机制等等。共识层13封装网络节点的各类共识算法。智能合约层14封装各类脚本、算法和智能合约。
本发明实施例的基于区块链的商品配送方法,可以在任何合适类型、具有运算能力的区块链节点中执行,例如服务器、台式计算机、智能手机、平板电脑以及其他电子产品中。其中,此处的服务器可以是一个物理服务器或者多个物理服务器虚拟而成的一个逻辑服务器。服务器也可以是多个可互联通信的服务器组成的服务器群,且各个功能模块可分别分布在服务器群中的各个服务器上。
本发明实施例提供的区块链包括诸如公有区块链(Public Block Chains)、联合区块链(Consortium Block Chains)及私有区块链(Private Block Chains)。
请参阅图2,图2是本发明实施例提供一种区块链系统的结构示意图。如图2所示,区块链系统200包括普通节点21、代理节点22、节点服务器23及共识节点24。
普通节点21持有流通的电子货币,在区块链系统中拥有投票选举的权利。普通节点21可以进行相关交易操作,但是没有区块的打包记账权,只能从拥有打包记账权的相关节点处同步记录区块数据。
在一些实施例中,普通节点21还可以完成商品配送工作。
代理节点22编写有智能合约代码,普通节点21向代理节点22发送原始区块数据,触发代理节点22的智能合约,使得代理节点的智能合约执行原始区块数据。其中,普通节点21维护有智能合约列表,该智能合约列表记录能够执行智能合约的各个代理节点名单。每当普通节点21接收到原始区块数据时,普通节点21调取智能合约列表,从智能合约列表中查找出各个代理节点的地址,并向各个代理节点发送原始区块数据。
在本实施例中,代理节点22可以预存多种类型智能合约,其可以根据普通节点21发送的触发请求,解析出智能合约的执行类型。代理节点22再根据解析出的智能合约的执行类型,执行对应的智能合约。
当某个代理节点陷入故障,其余代理节点将该某个代理节点的地址广播至全网,普通节点21监测到该广播信息,并更新智能合约列表,后续发送区块的原始数据时,普通节点21不向该某个代理节点22发送数据,以提高工作效率。
智能合约的代码是根据业务场景逻辑编写的,例如,在无人商店中,智能合约可以用于验证防伪溯源信息。
代理节点22根据智能合约执行原始区块数据后,输出待验证的区块数据。接着,代理节点22还将待验证的区块数据作签名,并将签名后的区块数据打包发送至共识节点24。共识节点24利用代理节点22的公钥验证签名后的区块数据,若验证成功,则认为该签名后的区块数据是合法代理节点22发送的,后续接着对该区块数据进行共识处理。若验证未成功,则认为该签名后的区块数据是非法代理节点22发送的。例如,代理节点22使用自身私钥对当前区块的哈希内容作签名运算,得到该签名。
在代理节点22的智能合约中,智能合约的合约内容可以预留有节点地址指向的节点服务器23。当执行智能合约时,代理节点22可以根据该节点地址,访问节点服务器23。
节点服务器23编写有相关逻辑代码,其可以按照相关逻辑代码完成商品配送工作。
共识节点24用于共识验证代理节点22上传的区块数据。其中,共识节点24可以支持以下任意一种共识算法:工作量证明(Proof of Work,PoW)、权益证明(Proof of Stake,POS)、股份授权证明(Delegate proof of Stake,DPoS)、实用拜占庭容错(practicalByzantine Fault Tolerance,PBFT)、授权拜占庭容错(Delegated Byzantine FaultTolerance,DBFT)等等。
每个共识节点24皆需要在代理节点22注册,待注册成功后,该共识节点便为合法共识节点。注册过程如下:
1、共识节点24向代理节点22提交注册信息。
其中,该注册信息包括以下一种或多种信息:共识节点24的设备序列号SN、用户信息及矿工钱包地址。
2、代理节点22对注册信息进行检查。
检查过程包括:检测SN编号格式是否正确、SN是否存在数据库中、SN是否已被绑定了其他用户等等。
3、代理节点22记录注册信息。
4、代理节点22将注册结果返回给共识节点24。
5、代理节点22将新的注册数据广播至区块链系统200。
在上述区块链系统200中,区块是用于存储交易摘要信息的载体,每个区块皆包含区块头与区块体,区块头记载的信息用于标识区块本身、前一个区块的信息摘要以及区块在整个账本中的位置。区块体用于存储交易摘要信息以及验证交易信息并保存交易不被篡改。
区块链为将每个区块按照生成时间的顺序逐个连接起来,便形成了一个链式的数据存储结构。在整个区块链中,第一个区块称为创世区块,其区块高度为0,之后的每个区块的区块高度依次加1,并且在区块头中写入前一个区块头的哈希值。区块链上的各个区块之间由各个区块上的上一个区块头哈希值进行链接。
因此,区块链具有不可篡改性。基于此,本发明实施例提供一种基于区块链的商品配送方法,基于区块链的商品配送方法应用于无人商店。
请参阅图3,图3是本发明实施例提供一种无人商店的结构示意图。如图3所示,该无人商店300设有结账区域30和商品区,商品区用于摆放商品,结账区域30用于对商品进行结算,该结账区域30设有第一出口31和第二出口32,当第一出口31开启时,结账区域30和商品区连通,用户可以从商品区进入该结账区域30,当第二出口32开启时,用户可以从结账区域30步行至无人商店300的外界环境,离开无人商店。
可选地,该结账区域30为“Z”形状,该第一出口31和第二出口32分别设置在该“Z”形状的结账区域。
该无人商店300还设有入口,该入口用于使用户进入该无人商店300,并且该入口只允许用户进入。
请一并参阅图3和图3a,该无人商店300还包括传感器33、摄像头34、射频读写设备35以及处理器36。
其中,传感器33、摄像头34以及射频读写设备35分别连接处理器36。
传感器33具体用于检测第一出口31的预设区域内是否存在用户的感应信号,当该预设区域内存在用户时,即触发该感应信号产生。该预设区域具体是商品区内接近第一出口31的区域,用户只有通过该区域才能进入结账区域30。因此,当检测到预设区域内存在用户的感应信号时,即表示有用户想离开无人商店,并且其当前状态是待进入结账区域30。
摄像头34包含多个,并且设置在无人商店300内,其具体设置在结账区域30内、第一出口31处、第二出口32处、无人商店300的进口处以及商品区等等。该摄像头34用于采集用户图像,并且将采集到的用户图像发送至处理器36。
在一些实施例中,摄像头34可以对同一用户进行运动轨迹追踪。例如,当无人商店300的进口处拍摄到用户A进入无人商店后,根据用户A在无人商店300内的活动区域,由该区域对应的摄像头34拍摄用户A的图像,一直到用户A离开该无人商店300,才结束对用户A的图像采集,获取用户A在无人商店内活动时的全部图像后,可以根据图像采集的先后顺序分析用户A的运动轨迹,从而可以根据该运动轨迹准确识别用户A,以及分析用户A所购买的商品的类别等。
射频读写设备35用于识别结账区域内是否存在商品,并且还用于读取用户所购买的商品的信息,该信息包括商品价格、商品品名、商品类别等等。该射频读写设备35将读取到的商品信息发送至处理器36。该射频读写设备35具体可以是RFID读写器。
处理器36用于接收传感器33、摄像头34以及射频读写设备35发送的相关信息,并且对这些相关信息进行处理。本实施例中的处理器36具体用于处理自动结账的问题。
具体地,当传感器33检测到第一出口31的预设区域内存在用户的感应信号后,将该感应信号发送至处理器36,此时,处理器36控制摄像头34采集该结账区域30内的第一区域图像,摄像头34将采集到的第一区域图像发送至处理器36。处理器36用于根据该第一区域图像,判断结账区域30内是否有人;如果没有人,控制第一出口31的门开启,以及控制摄像头34采集所述结账区域30的第二区域图像,并且获取所述第二区域图像,从而根据所述第二区域图像,判断所述结账区域30内是否只有一位用户;如果结账区域30内只有一位用户,并且通过射频读写设备35检测到结账区域30内存在商品时,则控制第一出口31的门关闭,以及获取所述用户的面部特征,并且根据所述面部特征获取所述用户的账号,以及通过所述射频读写设备35获取所述用户选购的商品信息以及其对应的价格;根据所述价格从所述用户的账号中扣除相应的金额,并且控制所述第二出口32的门开启。在这里,只有在结账区域30内只有一位用户并且存在商品时,才执行相应的结账操作,而且在结账时通过人脸识别来识别当前用户,从而能够准确的识别用户,以保证结账更准确。
请参阅图4,基于区块链的商品配送方法S400包括:
S41、普通节点向代理节点发送外卖下单请求;
在本实施例中,用户打开无人商店APP,在无人商店APP的界面上选择商品,并下单。于是,无人商店APP向普通节点发起外卖下单请求,普通节点将外卖下单请求转发给代理节点。
S42、代理节点根据外卖下单请求,执行智能合约,以产生支付码,并向智能合约预留的节点地址对应的节点服务器发送外卖下单请求与支付码,支付码包括商品信息;
在本实施例中,支付码包括商品信息与用户信息,用户信息诸如为以上的用户姓名、联系方式、送货地址等等,商品信息诸如为商品名称、商品数量等等。
代理节点通过普通节点向配送人员推送外卖送单信息。于是,配送人员根据外卖送单信息,开始实施抢单。其中,配送人员为已注册的,并且注册信息录入服务器内。
S43、普通节点向代理节点发送抢单请求;
S44、代理节点根据抢单请求,执行智能合约,以确定目标配送人员的身份信息,并向普通节点发送目标配送人员的身份信息以及支付码;
在本实施例中,各个配送人员向普通节点发起抢单请求,于是,普通节点向代理节点转发该抢单请求,代理节点接收抢单请求并根据抢单请求确定目标配送人员的身份信息,以及,生成支付码。代理节点将目标配送人员的身份信息以及支付码向普通节点发送,普通节点再向目标配送人员推送支付码,目标配送人员便可以在无人商店内使用该支付码获得并配送外卖。
在一些实施例中,当一片区域布置了多家无人商店,由于多家无人商店互相通信,并支持外卖配送,配送人员在任意一家无人商店,仅凭支付码便可以配送外卖。
在一些实施例中,代理节点存储有信用列表,信用列表包括每个配送人员的身份信息与信用分数,抢单请求携带有配送人员的地理位置,外卖下单请求携带有外卖地址。
代理节点根据抢单请求,执行智能合约,以确定目标配送人员的身份信息的过程中,代理节点根据抢单请求,执行智能合约,以获取信用列表,并根据信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息,举例而言:首先,代理节点根据公式:y=-2.5x+10+M,计算出每个配送人员总得分,其中,y为每个配送人员总得分,x为配送人员的地理位置与外卖地址之间的相对距离,M为配送人员的信用分数。其次,代理节点确定总得分最高的配送人员作为目标配送人员,并得到目标配送人员的身份信息。其中,x的取值范围为0-4。例如,配送人员A的当前地理位置距离外卖地址3公里,信用分数为6分。配送人员B的当前地理位置距离外卖地址2.5公里,信用分数为5分,由于配送人员A的总得分为8.5,配送人员B的总得分为8.75,于是,系统选择配送人员B作为目标配送人员。配送人员C的当前地理位置距离外卖地址5公里,由于系统不支持远距离的配送,即使配送人员C的总得分很高,系统也不会选择配送人员C作为目标配送人员。
S45、节点服务器建立外卖下单请求、支付码及目标配送人员的身份信息之间映射关系的下单列表;
在本实施例中,为了缓解代理节点的数据处理压力,在编写代理节点的智能合约的合约内容时,预留有该节点服务器的节点地址,待执行至该节点地址对应的逻辑时,代理节点向节点服务器发送目标配送人员的身份信息,以使节点服务器建立起外卖下单请求、支付码及目标配送人员的身份信息之间映射关系的下单列表。
S46、普通节点在检测支付码为合法支付码时,根据支付码的商品信息,自动取出与商品信息对应的商品,并向代理节点发送取单成功请求;
在本实施例中,配送人员使用支付码配送外卖时,首先,无人商店的扫描设备先识别出支付码,并将支付码传输给普通节点,普通节点检测支付码是否为合法支付码,若为合法支付码,普通节点根据支付码的商品信息,自动取出与商品信息对应的商品;若为非法支付码,普通节点不会自动取出与商品信息对应的商品。
S47、代理节点根据取单成功请求,从节点服务器中获取下单列表,并生成包含下单列表的区块数据。
S48、代理节点向共识节点发送区块数据,以使共识节点共识验证区块数据。
代理节点将区块数据发送给共识节点时,代理节点使用自身私钥对区块数据作签名运算,得到区块签名,其中与私钥对应的公钥广播至区块链系统。其次,代理节点再将区块签名与区块数据封装并向共识节点发送,共识节点验证签名后的区块数据时,共识节点使用代理节点的合法公钥验证区块签名,若区块签名合法,便认为区块数据由合法代理节点发送的。若区块签名非法,便认为区块数据由非法代理节点发送的,因此,采用此种方式能够提高区块数据的安全性。
当共识节点验证区块数据为合法代理节点发送时,各个共识节点采用股份证明算法(Proof of Stake,POS)或者委任权益证明算法(Delegated Proof of Stake,DPOS)对区块数据进行验证。当验证通过该区块数据后,共识节点补全其它区块信息,其它区块信息包括区块签名、时间戳等等,打包新区块数据,广播全网。
当共识节点验证区块数据为非法代理节点发送的,丢弃该区块数据。
由于区块链具有不可篡改、去中心化及高度透明化的特点,因此,其能够提供公平配送外卖的平台。
在一些实施例中,该基于区块链的商品配送方法应用于联盟链,当采用股份授权证明算法作为共识机制时,股份授权证明算法的股份占比按照各个运营商的无人商店规模分配。例如,联盟链的各个区块链节点为无人商店的各个运营商架设的服务器,无人商店规模包括无人商店总面积或注册用户量等等。其中,运营商A的无人商店规模最大,占比为10%,运营商B为6%,运营商C为3%......,以此类推。
有些共识节点陷入故障或者作恶(不签署验证新区块链数据),为了保证区块链系统能够正常出块,其余共识节点可以作视图更新,停止故障或作恶共识节点的共识权利。因此,在一些实施例中,共识节点共识验证区块数据的过程中,在检测到共识验证失败的次数大于预设阈值时,共识节点组成的共识服务器群确定恶意共识节点,恶意共识节点为未签署验证区块数据并导致共识验证失败次数最多的节点。共识节点组成的共识服务器群禁止恶意共识节点参与共识验证,并在剩余的共识节点重新分配股份并共识验证区块数据,例如,占比为10%的共识节点A作恶,于是,首先共识服务器群停止共识节点A的投票权利,其次,共识服务器将共识节点A的占比10%按照预设规则分配给其余共识节点,例如,均分给其余共识节点,或者,按照共识节点的工作年龄分配给其余节点,工作年龄越长,分配占比越高,工作年龄越短,分配占比越低。
再次,共识服务器群在检测到共识验证失败的次数小于预设阈值时,继续共识验证区块数据。
采用此种方式,其保证区块链系统能够顺利出块。
需要说明的是,在上述各个实施例中,上述各步骤之间并不必然存在一定的先后顺序,本领域普通技术人员,根据本发明实施例的描述可以理解,不同实施例中,上述各步骤可以有不同的执行顺序,亦即,可以并行执行,亦可以交换执行等等。
作为本发明实施例另一方面,本发明实施例提供一种基于区块链的商品配送系统。基于区块链的商品配送系统包括:若干普通节点及代理节点。普通节点向代理节点发送外卖下单请求;所述代理节点根据所述外卖下单请求,执行智能合约,以产生支付码,并向所述智能合约预留的节点地址对应的节点服务器发送所述外卖下单请求与所述支付码,所述支付码包括商品信息;所述普通节点向所述代理节点发送抢单请求;所述代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,并向所述普通节点发送所述目标配送人员的身份信息以及所述支付码;所述节点服务器建立所述外卖下单请求、所述支付码及所述目标配送人员的身份信息之间映射关系的下单列表;所述普通节点在检测所述支付码为合法支付码时,根据所述支付码的商品信息,自动取出与所述商品信息对应的商品,并向所述代理节点发送取单成功请求;所述代理节点根据所述取单成功请求,从所述节点服务器中获取所述下单列表,并生成包含所述下单列表的区块数据。
在一些实施例中,所述代理节点存储有信用列表,所述信用列表包括每个配送人员的身份信息与信用分数,所述抢单请求携带有配送人员的地理位置,所述外卖下单请求携带有外卖地址。
所述代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,包括:所述代理节点根据所述抢单请求,执行所述智能合约,以获取所述信用列表,并根据所述信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息。
在一些实施例中,所述代理节点根据所述信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息,包括:所述代理节点根据公式:y=-2.5x+10+M,计算出每个配送人员总得分,其中,y为每个配送人员总得分,x为配送人员的地理位置与外卖地址之间的相对距离,M为配送人员的信用分数;所述代理节点确定总得分最高的配送人员作为目标配送人员,并得到所述目标配送人员的身份信息。
在一些实施例中,所述x的取值范围为0-4。
在一些实施例中,生成包含所述下单列表的区块数据后,所述代理节点向共识节点发送所述区块数据,以使所述共识节点共识验证所述区块数据。
以上所描述的装置或设备实施例仅仅是示意性的,其中所述作为分离部件说明的单元模块可以是或者也可以不是物理上分开的,作为模块单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络模块单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到各实施方式可借助软件加通用硬件平台的方式来实现,当然也可以通过硬件。基于这样的理解,上述技术方案本质上或者说对相关技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在计算机可读存储介质中,如ROM/RAM、磁碟、光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行各个实施例或者实施例的某些部分所述的方法。
最后应说明的是:以上实施例仅用以说明本发明的技术方案,而非对其限制;在本发明的思路下,以上实施例或者不同实施例中的技术特征之间也可以进行组合,步骤可以以任意顺序实现,并存在如上所述的本发明的不同方面的许多其它变化,为了简明,它们没有在细节中提供;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的范围。
Claims (10)
1.一种基于区块链的商品配送方法,其特征在于,所述方法包括:
普通节点向代理节点发送外卖下单请求;
所述代理节点根据所述外卖下单请求,执行智能合约,以产生支付码,并向所述智能合约预留的节点地址对应的节点服务器发送所述外卖下单请求与所述支付码,所述支付码包括商品信息;
所述普通节点向所述代理节点发送抢单请求;
所述代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,并向所述普通节点发送所述目标配送人员的身份信息以及所述支付码;
所述节点服务器建立所述外卖下单请求、所述支付码及所述目标配送人员的身份信息之间映射关系的下单列表;
所述普通节点在检测所述支付码为合法支付码时,根据所述支付码的商品信息,自动取出与所述商品信息对应的商品,并向所述代理节点发送取单成功请求;
所述代理节点根据所述取单成功请求,从所述节点服务器中获取所述下单列表,并生成包含所述下单列表的区块数据。
2.根据权利要求1所述的方法,其特征在于,所述代理节点存储有信用列表,所述信用列表包括每个配送人员的身份信息与信用分数,所述抢单请求携带有配送人员的地理位置,所述外卖下单请求携带有外卖地址;
所述代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,包括:
所述代理节点根据所述抢单请求,执行所述智能合约,以获取所述信用列表,并根据所述信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息。
3.根据权利要求2所述的方法,其特征在于,所述代理节点根据所述信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息,包括:
所述代理节点根据公式:y=-2.5x+10+M,计算出每个配送人员总得分,其中,y为每个配送人员总得分,x为配送人员的地理位置与外卖地址之间的相对距离,M为配送人员的信用分数;
所述代理节点确定总得分最高的配送人员作为目标配送人员,并得到所述目标配送人员的身份信息。
4.根据权利要求3所述的方法,其特征在于,所述x的取值范围为0-4。
5.根据权利要求1至4任一项所述的方法,其特征在于,生成包含所述下单列表的区块数据后,所述方法还包括:
所述代理节点向共识节点发送所述区块数据,以使所述共识节点共识验证所述区块数据。
6.一种基于区块链的商品配送系统,其特征在于,所述系统包括:若干普通节点及代理节点;
普通节点向代理节点发送外卖下单请求;
所述代理节点根据所述外卖下单请求,执行智能合约,以产生支付码,并向所述智能合约预留的节点地址对应的节点服务器发送所述外卖下单请求与所述支付码,所述支付码包括商品信息;
所述普通节点向所述代理节点发送抢单请求;
所述代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,并向所述普通节点发送所述目标配送人员的身份信息以及所述支付码;
所述节点服务器建立所述外卖下单请求、所述支付码及所述目标配送人员的身份信息之间映射关系的下单列表;
所述普通节点在检测所述支付码为合法支付码时,根据所述支付码的商品信息,自动取出与所述商品信息对应的商品,并向所述代理节点发送取单成功请求;
所述代理节点根据所述取单成功请求,从所述节点服务器中获取所述下单列表,并生成包含所述下单列表的区块数据。
7.根据权利要求6所述的系统,其特征在于,所述代理节点存储有信用列表,所述信用列表包括每个配送人员的身份信息与信用分数,所述抢单请求携带有配送人员的地理位置,所述外卖下单请求携带有外卖地址;
所述代理节点根据所述抢单请求,执行所述智能合约,以确定目标配送人员的身份信息,包括:
所述代理节点根据所述抢单请求,执行所述智能合约,以获取所述信用列表,并根据所述信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息。
8.根据权利要求7所述的系统,其特征在于,所述代理节点根据所述信用列表、每个配送人员的地理位置以及外卖地址,确定目标配送人员的身份信息,包括:
所述代理节点根据公式:y=-2.5x+10+M,计算出每个配送人员总得分,其中,y为每个配送人员总得分,x为配送人员的地理位置与外卖地址之间的相对距离,M为配送人员的信用分数;
所述代理节点确定总得分最高的配送人员作为目标配送人员,并得到所述目标配送人员的身份信息。
9.根据权利要求8所述的系统,其特征在于,所述x的取值范围为0-4。
10.根据权利要求6至9任一项所述的系统,其特征在于,生成包含所述下单列表的区块数据后,所述代理节点向共识节点发送所述区块数据,以使所述共识节点共识验证所述区块数据。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811033491.4A CN109102209A (zh) | 2018-09-05 | 2018-09-05 | 一种基于区块链的商品配送方法及其系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811033491.4A CN109102209A (zh) | 2018-09-05 | 2018-09-05 | 一种基于区块链的商品配送方法及其系统 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN109102209A true CN109102209A (zh) | 2018-12-28 |
Family
ID=64865377
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201811033491.4A Pending CN109102209A (zh) | 2018-09-05 | 2018-09-05 | 一种基于区块链的商品配送方法及其系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109102209A (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110414203A (zh) * | 2019-07-26 | 2019-11-05 | 郑州大学 | 一种基于区块链技术的互联网医疗身份认证方法 |
CN110633886A (zh) * | 2019-04-01 | 2019-12-31 | 邓继红 | 基于区块链的网络数据发送平台、方法及存储介质 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2012154984A2 (en) * | 2011-05-10 | 2012-11-15 | Restaurant Revolution Technologies, Inc. | Systems and methods for take-out order management |
CN104361474A (zh) * | 2014-10-10 | 2015-02-18 | 深圳市迅享科技有限公司 | 一种外卖配送员抢单的方法及系统 |
CN106485441A (zh) * | 2016-09-13 | 2017-03-08 | 合肥壹客送网络科技有限公司 | 一种外卖配送方法及系统 |
CN106603698A (zh) * | 2016-12-28 | 2017-04-26 | 北京果仁宝科技有限公司 | 基于dpos的区块链共识方法和节点 |
CN107909451A (zh) * | 2017-12-14 | 2018-04-13 | 吴怡锦 | 一种线上购物后即可线下取货的自动售货系统及方法 |
CN108182581A (zh) * | 2017-12-29 | 2018-06-19 | 北京欧链科技有限公司 | 一种区块链的记账方法及装置 |
CN108446871A (zh) * | 2018-02-09 | 2018-08-24 | 北京三快在线科技有限公司 | 一种订单的配送处理方法及装置 |
-
2018
- 2018-09-05 CN CN201811033491.4A patent/CN109102209A/zh active Pending
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2012154984A2 (en) * | 2011-05-10 | 2012-11-15 | Restaurant Revolution Technologies, Inc. | Systems and methods for take-out order management |
CN104361474A (zh) * | 2014-10-10 | 2015-02-18 | 深圳市迅享科技有限公司 | 一种外卖配送员抢单的方法及系统 |
CN106485441A (zh) * | 2016-09-13 | 2017-03-08 | 合肥壹客送网络科技有限公司 | 一种外卖配送方法及系统 |
CN106603698A (zh) * | 2016-12-28 | 2017-04-26 | 北京果仁宝科技有限公司 | 基于dpos的区块链共识方法和节点 |
CN107909451A (zh) * | 2017-12-14 | 2018-04-13 | 吴怡锦 | 一种线上购物后即可线下取货的自动售货系统及方法 |
CN108182581A (zh) * | 2017-12-29 | 2018-06-19 | 北京欧链科技有限公司 | 一种区块链的记账方法及装置 |
CN108446871A (zh) * | 2018-02-09 | 2018-08-24 | 北京三快在线科技有限公司 | 一种订单的配送处理方法及装置 |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110633886A (zh) * | 2019-04-01 | 2019-12-31 | 邓继红 | 基于区块链的网络数据发送平台、方法及存储介质 |
CN110414203A (zh) * | 2019-07-26 | 2019-11-05 | 郑州大学 | 一种基于区块链技术的互联网医疗身份认证方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109034851A (zh) | 基于区块链的商品防伪溯源方法及其装置、区块链节点 | |
CN109146645A (zh) | 基于区块链的商品推荐方法、区块链节点及系统 | |
CN109102308A (zh) | 基于区块链的商品信息维护方法、区块链节点及其系统 | |
CN109146573A (zh) | 基于区块链的商品积分方法及其装置、区块链节点 | |
CN109272383A (zh) | 基于区块链的商品信息生成方法、区块链节点及其系统 | |
CN109146499A (zh) | 基于区块链的用户信用调整方法及其装置、区块链节点 | |
US20200082396A1 (en) | Electronic tag and system and method for securing electronic tag | |
US20190188732A1 (en) | System and method for ensuring credibility of items in a supply chain management | |
EP3174240A1 (en) | Digital token system for physical medium digitalization and physical store optimization | |
CN109191108A (zh) | 基于区块链的二维码聚合支付系统及其工作方法 | |
JP3632767B2 (ja) | 個人認証方法 | |
KR20180006338A (ko) | 식별 가능 태그와 인공지능을 이용한 결제수단과 문서 전산관리 방법 및 시스템 | |
CN105378774A (zh) | 安全交易系统和方法 | |
US20060080198A1 (en) | Cash transaction system | |
CN105096134A (zh) | 用于验证数字实体及聚合对象来源的安全方案的系统及方法 | |
KR102058159B1 (ko) | 정품인증코드를 이용한 물품거래 이력 관리방법 및 프로그램 | |
CN109255709A (zh) | 一种基于区块链的结账方法及其系统 | |
JPH10154192A (ja) | 電子マネーシステム及び記録媒体 | |
RU2691601C2 (ru) | Персональная сеть | |
CN109102209A (zh) | 一种基于区块链的商品配送方法及其系统 | |
CN109858222A (zh) | 一种基于人脸特征的身份验证区块链系统及其验证方法 | |
JP7419628B2 (ja) | 情報をデータベースに登録する先進的な方法、システム及びデバイス | |
US20200051056A1 (en) | Advanced methods, systems and devices for registering information in a database | |
CN110476398A (zh) | 利用接近网络数据的欺骗性无线网络检测 | |
CN116029733B (zh) | 一种联盟景区业务管理方法及系统 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20181228 |
|
RJ01 | Rejection of invention patent application after publication |