时间戳标签打印方法及系统
技术领域
本发明涉及时间戳防伪技术领域,具体而言,涉及时间戳标签打印方法及系统。
背景技术
在商品时间戳标签打印中,多数厂家采用时间戳(timestamp)来标记时间戳标签打印日期。时间戳通常是一个字符序列,可以唯一地标识某一刻的时间。通常,厂家对标签的使用过程为:厂家首先设置标签内容并申请时间戳,然后打印带有时间戳的标签,最后粘贴该标签到商品或商品包装上。一般来说,时间戳申请的过程为:厂家首先将需要加时间戳的标签用Hash编码加密形成摘要,然后将该摘要发送到时间戳服务器,时间戳服务器在加入了收到标签摘要的日期和时间信息后再对该标签加密(数字签名),然后送回厂家。这样,时间戳标签打印的时间是由时间戳服务器来加的,以时间戳服务器收到文件的时间为依据,因而可以为标签的时间信息提供安全保护。然而,很多厂家常常采用“先申请,后打印”的方式伪造标签上的时间戳,使得标签上的时间戳与实际打印时间不一致。
发明内容
本发明正是基于上述问题,提出了时间戳标签打印方法及系统,可以有效防止伪造标签上的时间戳。
有鉴于此,本发明的一方面提出了一种时间戳标签打印方法,包括:
响应厂家的时间戳申请请求,生成至少一时间戳,并合并所有所述时间戳为一封包;
生成动态密钥,并使用该动态密钥对所述封包进行加密;
生成一凭据,在对该凭据与所述动态密钥进行关联后,发送加密后的封包和所述凭据至打标机;
响应厂家的标签打印请求,接收所述打标机反馈的凭据,判断反馈的凭据是否在有效期内;
当所述凭据在有效期内时,发送与该凭据关联的动态密钥至所述打标机,使得所述打标机可以从所述封包获取所述时间戳的数据信息并打印包含所述时间戳的数据信息的标签。
进一步地,所述“响应厂家的时间戳申请请求,生成至少一时间戳”包括:
响应厂家的时间戳申请请求,获取来自所述打标机的申请数量信息;
检测使用设定的私钥公钥组中的公钥能否对所述申请数量信息进行解密;
当检测结果为是时,生成对应数量的时间戳;反之,生成并反馈未授权提示信息至所述打标机。
进一步地,所述“响应厂家的时间戳申请请求,生成至少一时间戳,并合并所有所述时间戳为一封包”包括:
响应厂家的时间戳申请请求,获取来自所述打标机的申请数量信息;
生成对应数量的时间戳,并使用设定的私钥公钥组中的私钥对所述时间戳加密;其中,所述时间戳包括文本日期和/或包含时间戳的数据信息的二维码;
合并加密后的所述时间戳为一封包。
进一步地,所述时间戳标签打印方法还包括:
响应消费者对标签上二维码的扫描操作,公布所述私钥公钥组中的公钥至该消费者,使得该消费者可以从所述二维码获取所述时间戳的数据信息,及对比所述时间戳的数据信息和所述文本信息,从而识别所述标签的真伪。
进一步地,所述“判断反馈的凭据是否在有效期内”包括:
当发送所述凭据至打标机时,记录凭据发送时间;
当接收到所述打标机反馈的凭据时,记录凭据反馈时间;
根据所述凭据发送时间和所述凭据反馈时间计算时间差;
比较所述时间差是否超过存储的有效期。
本发明另一方面提供了一种时间戳标签打印系统,包括:
封包模块,用于响应厂家的时间戳申请请求,生成至少一时间戳,并合并所有所述时间戳为一封包;
加密模块,用于生成动态密钥,并使用该动态密钥对所述封包进行加密;
凭据模块,用于生成一凭据,在对该凭据与所述动态密钥进行关联后,发送加密后的封包和所述凭据至打标机;
判断模块,用于响应厂家的标签打印请求,接收所述打标机反馈的凭据,判断反馈的凭据是否在有效期内;
解密模块,用于当所述凭据在有效期内时,发送与该凭据关联的动态密钥至所述打标机,使得所述打标机可以从所述封包获取所述时间戳的数据信息并打印包含所述时间戳的数据信息的标签。
进一步地,所述封包模块包括:
获取单元,用于响应厂家的时间戳申请请求,获取来自所述打标机的申请数量信息;
检测单元,用于检测使用设定的私钥公钥组中的公钥能否对所述申请数量信息进行解密;
生成单元,用于当检测结果为是时,生成对应数量的时间戳;反之,生成并反馈未授权提示信息至所述打标机。
进一步地,所述封包模块包括:
获取单元,用于响应厂家的时间戳申请请求,获取来自所述打标机的申请数量信息;
生成单元,用于生成对应数量的时间戳;其中,所述时间戳包括文本日期和/或包含时间戳的数据信息的二维码;
加密单元,用于使用设定的私钥公钥组中的私钥对所述时间戳加密;
封包单元,用于合并加密后的所述时间戳为一封包。
进一步地,所述时间戳标签打印系统还包括:
公布模块,用于响应消费者对标签上二维码的扫描操作,公布所述私钥公钥组中的公钥至该消费者,使得该消费者可以从所述二维码获取时间戳的数据信息,及对比所述时间戳的数据信息和所述文本信息,从而识别所述标签的真伪。
进一步地,所述判断模块包括:
记录单元,用于当发送所述凭据至打标机时,记录凭据发送时间,及当接收到所述打标机反馈的凭据时,记录凭据反馈时间;
计算单元,用于根据所述凭据发送时间和所述凭据反馈时间计算时间差;
比较单元,用于比较所述时间差是否超过存储的有效期。
本实施例提供的时间戳标签打印方法及系统,厂家在获取到包含时间戳的数据信息的封包和凭据后,必须在指定时间内反馈凭据以换取关联的动态密钥,才可以获取从所述封包获取所述时间戳的数据信息,否则,申请到的时间戳失效,可以有效防止伪造标签上的时间戳。
为使本发明的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图,作详细说明如下。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1示出了第一实施例提供的时间戳标签打印方法的流程示意图;
图2示出了第二实施例提供的时间戳标签打印方法的第一流程示意图;
图3示出了第二实施例提供的时间戳标签打印方法的第二流程示意图;
图4示出了本发明实施例提供的时间戳标签打印系统的结构示意图。
主要元件符号说明:
100-时间戳标签打印系统;10-封包模块;20-加密模块;30-凭据模块40-判断模块;50-解密模块;60-公布模块。
具体实施方式
为了便于理解本发明,下面将参照相关附图对时间戳标签打印方法及系统进行更清楚、完整地描述。附图中给出了时间戳标签打印方法及系统的优选实施例。时间戳标签打印方法及系统可以通过许多不同的形式来实现,并不限于本文所描述的实施例。因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
实施例1
图1示出了本发明实施例提供的时间戳标签打印方法的流程示意图。
如图1所示,本发明实施例提供的时间戳标签打印方法,应用于时间戳服务器,包括:
步骤S1,响应厂家的时间戳申请请求,生成至少一时间戳,并合并所有所述时间戳为一封包。
具体地,响应厂家的时间戳申请请求,获取厂家对时间戳的申请数量信息,并生成对应数量的时间戳。本实施例中,所述时间戳为可以唯一地标识某一刻的时间的字符序列,如2016年10月21日。另一实施例中,所述时间戳为包含时间信息的识别码,如二维码、条形码等。
进一步地,将生成的所有时间戳合并为一封包。所述封包内包含一个或多个时间戳的数据信息。封包的设置不仅避免了多个时间戳需要多次反馈给厂家的繁琐,同时便于对厂家申请的一批时间戳进行统一处理,如加密或解密等,提高了时间戳的申请效率。
步骤S2,生成动态密钥,并使用该动态密钥对所述封包进行加密。
本实施例中,采用对称加密的方式对封包进行加密,即加密和解密使用相同密钥。另一实施例中,采用非对称加密的方式对封包进行加密,即加密和解密使用两个不同的密钥:公钥(publickey)和私钥(privatekey)。用户可以根据实际需求等选择具体的加密方式,这里不做限制。
具体地,在合并生成一封包后,生成一动态密钥,并用该该动态密钥对所述封包进行对称加密。
步骤S3,生成一凭据,在对该凭据与所述动态密钥进行关联后,发送加密后的封包和所述凭据至打标机。
具体地,在生成所述动态密钥的同时,生成一凭据,并关联该凭据与所述动态密钥。所述凭据为打标机在指定时间内换取动态密钥的凭证。进一步地,在关联该凭据与所述动态密钥后,发送所述封包和所述凭据至打标机。优选地,当发送所述凭据至打标机时,记录凭据发送时间。
步骤S4,响应厂家的标签打印请求,接收所述打标机反馈的凭据,判断反馈的凭据是否在有效期内。
本实施例中,当厂家进行标签打印时,首先需要在指定时间内反馈收到的凭据以换取关联的动态密钥,才可以获取从所述封包获取所述时间戳的数据信息。
具体地,响应厂家的标签打印请求,接收所述打标机反馈的凭据,并记录凭据反馈时间。根据所述凭据发送时间和所述凭据反馈时间计算时间差。比较所述时间差是否超过存储的有效期。所述有效期为凭据维持有效的时间长度,本实施例中,所述有效期为1分钟,当然,所述有效期可以根据实际应用设置为其他时间长度,这里不做限制。容易理解,为了避免伪造时间戳,设置的有效期不宜太长,应尽可能的缩短从时间戳申请到时间戳打印的时间间隔。
步骤S5,当所述凭据在有效期内时,发送与该凭据关联的动态密钥至所述打标机。
本实施例中,仅当所述凭据在有效期内时,发送与该凭据关联的动态密钥至所述打标机,使得所述打标机可以从所述封包获取所述时间戳的数据信息并打印包含所述时间戳的数据信息的标签。当所述凭据不在有效期内时,拒绝提供动态密钥,从而厂家申请到的时间戳失效,打标机不能打印包含所述时间戳的数据信息的标签。
本实施例提供的时间戳标签打印方法,厂家在获取到包含时间戳的数据信息的封包和凭据后,必须在指定时间内反馈凭据以换取关联的动态密钥,才可以获取从所述封包获取所述时间戳的数据信息,否则,申请到的时间戳失效,可以有效防止伪造标签上的时间戳。
实施例2
图2示出了本发明实施例提供的时间戳标签打印方法的流程示意图。
如图2所示,本发明实施例提供的时间戳标签打印方法,应用于时间戳服务器,包括:
步骤S11,响应厂家的时间戳申请请求,获取来自所述打标机的申请数量信息。
具体地,响应厂家在一打标机的时间戳申请请求,获取来自该打标机的申请数量信息。所述申请数量信息为厂家申请的时间戳的数量,可以是一个或多个。
步骤S12,检测使用设定的私钥公钥组中的公钥能否对所述申请数量信息进行解密。
需要说明的是,本实施例中,并非响应厂家在任意打标机的时间戳申请请求,而是仅响应来自经过授权的打标机的时间戳申请请求,以此避免厂家通过未授权的打标机规避本实施例提供的时间戳标签打印方法的时间戳防伪手段。
具体地,响应厂家在一打标机的时间戳申请请求,检测该时间戳申请请求是否为经过设定的私钥公钥组中的私钥加密,当所述时间戳申请请求经过所述私钥加密时,表示该打标机已授权。所述设定的私钥公钥组包括对数据进行加密和解密的一对密钥,即公钥和私钥。如果用公钥对数据进行加密,只有用对应的私钥才能解密;如果用私钥对数据进行加密,那么只有用对应的公钥才能解密。
进一步地,对厂家发出的时间戳申请请求是否经过设定的私钥公钥组中的私钥加密的判断方式为:检测使用设定的私钥公钥组中的公钥能否对所述申请数量信息进行解密。可以理解,当使用设定的私钥公钥组中的公钥可以对所述申请数量信息进行解密时,表示该打标机已授权;反之,表示该打标机未授权。
步骤S13,当检测结果为否时,生成并反馈未授权提示信息至所述打标机。
当使用设定的私钥公钥组中的公钥不能对所述申请数量信息进行解密时,生成未授权提示信息,并反馈该未授权提示信息至所述打标机。所述未授权信息为用于提示厂家应在授权的打标机发出时间戳申请的文本、图片或语音等信息。
步骤S14,当检测结果为是时,生成对应数量的时间戳,并使用设定的私钥公钥组中的私钥对所述时间戳加密。
具体地,当使用设定的私钥公钥组中的公钥可以对所述申请数量信息进行解密时,响应该时间戳申请请求,生成对应数量的时间戳。本实施例中,所述时间戳包括文本日期和/或包含时间戳的数据信息的二维码制作数据。更具体地,所述文本日期为可以唯一地标识某一刻的时间的字符序列,如2016年10月21日;所述时间戳的数据信息为某一刻的时间信息。进一步地,使用所述私钥公钥组中的私钥对生成的每一时间戳进行加密。
步骤S15,合并加密后的所述时间戳为一封包。
具体地,将加密后的所有时间戳合并为一封包。所述封包内包含一个或多个时间戳的数据信息。
步骤S16,生成动态密钥,并使用该动态密钥对所述封包进行加密。
其中,步骤S16和步骤S2内容相同。
步骤S17,生成一凭据,在对该凭据与所述动态密钥进行关联后,发送加密后的封包和所述凭据至打标机。
其中,步骤S17和步骤S3内容相同。
步骤S18,响应厂家的标签打印请求,接收所述打标机反馈的凭据,判断反馈的凭据是否在有效期内。
其中,步骤S18和步骤S4内容相同。
步骤S19,当所述凭据在有效期内时,发送与该凭据关联的动态密钥至所述打标机。
其中,步骤S19和步骤S5内容相同。
步骤S20,响应消费者对标签上二维码的扫描操作,公布所述私钥公钥组中的公钥至该消费者。
本实施例中,打标机根据从封包内获取的时间戳的数据信息打印出的标签包括文本日期和包含时间戳的数据信息的二维码。当厂家粘贴该标签至商品或商品包装上时,消费者可以通过扫描所述二维码获取时间戳的数据信息,并对比所述时间戳的数据信息和所述文本信息,从而识别所述标签的真伪。
请一并参阅图3所示,本实施例提供的时间戳标签打印方法,不仅可以有效防止伪造标签上的时间戳,还可以有效防止伪造标签,更大程度上降低了伪造时间戳的可能性。
实施例3
图4示出了本发明实施例提供的时间戳标签打印系统的结构示意图。
如图4所示,本发明实施例提供的时间戳标签打印系统100,包括封包模块10、加密模块20、凭据模块30、判断模块40和解密模块50。
封包模块10用于响应厂家的时间戳申请请求,生成至少一时间戳,并合并所有所述时间戳为一封包。本实施例中,封包模块10包括获取单元、检测单元、生成单元、加密单元和封包单元。
获取单元,用于响应厂家的时间戳申请请求,获取来自所述打标机的申请数量信息。
检测单元,用于检测使用设定的私钥公钥组中的公钥能否对所述申请数量信息进行解密。
生成单元,用于当检测结果为是时,生成对应数量的时间戳;反之,生成并反馈未授权提示信息至所述打标机。其中,所述时间戳包括文本日期和/或包含时间戳的数据信息的二维码。
加密单元,用于使用设定的私钥公钥组中的私钥对所述时间戳加密。
封包单元,用于合并加密后的所述时间戳为一封包。
加密模块20用于生成动态密钥,并使用该动态密钥对所述封包进行加密。
凭据模块30用于生成一凭据,在对该凭据与所述动态密钥进行关联后,发送加密后的封包和所述凭据至打标机。
判断模块40用于响应厂家的标签打印请求,接收所述打标机反馈的凭据,判断反馈的凭据是否在有效期内。本实施例中,判断模块40包括记录单元、计算单元和比较单元。
记录单元,用于当发送所述凭据至打标机时,记录凭据发送时间,及当接收到所述打标机反馈的凭据时,记录凭据反馈时间。
计算单元,用于根据所述凭据发送时间和所述凭据反馈时间计算时间差。
比较单元,用于比较所述时间差是否超过存储的有效期。
解密模块50用于当所述凭据在有效期内时,发送与该凭据关联的动态密钥至所述打标机,使得所述打标机可以从所述封包获取所述时间戳的数据信息并打印包含所述时间戳的数据信息的标签。
本实施例中,时间戳标签打印系统100还包括公布模块60。
公布模块60用于响应消费者对标签上二维码的扫描操作,公布所述私钥公钥组中的公钥至该消费者,使得该消费者可以从所述二维码获取时间戳的数据信息,及对比所述时间戳的数据信息和所述文本信息,从而识别所述标签的真伪。
本实施例提供的时间戳标签打印方法及系统,厂家在获取到包含时间戳的数据信息的封包和凭据后,必须在指定时间内反馈凭据以换取关联的动态密钥,才可以获取从所述封包获取所述时间戳的数据信息,否则,申请到的时间戳失效,可以有效防止伪造标签上的时间戳。
本发明实施例所提供的系统,其实现原理及产生的技术效果和前述方法实施例相同,为简要描述,系统实施例部分未提及之处,可参考前述方法实施例中相应内容。
在这里示出和描述的所有示例中,任何具体值应被解释为仅仅是示例性的,而不是为限制,因此,示例性实施例的其他示例可以具有不同的值。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,又例如,多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些通信接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述为分离部件说明的单元可以是或者也可以不是物理上分开的,为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。