CN110097159B - 一种基于汉明码的qr码安全认证方法及系统 - Google Patents

一种基于汉明码的qr码安全认证方法及系统 Download PDF

Info

Publication number
CN110097159B
CN110097159B CN201910353278.XA CN201910353278A CN110097159B CN 110097159 B CN110097159 B CN 110097159B CN 201910353278 A CN201910353278 A CN 201910353278A CN 110097159 B CN110097159 B CN 110097159B
Authority
CN
China
Prior art keywords
code
information
module
data
authentication information
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.)
Active
Application number
CN201910353278.XA
Other languages
English (en)
Other versions
CN110097159A (zh
Inventor
李黎
张善卿
陆剑锋
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Shaoxing Conglomerate Data Technology Co ltd
Hangzhou Dianzi University
Original Assignee
Shaoxing Conglomerate Data Technology Co ltd
Hangzhou Dianzi University
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Shaoxing Conglomerate Data Technology Co ltd, Hangzhou Dianzi University filed Critical Shaoxing Conglomerate Data Technology Co ltd
Priority to CN201910353278.XA priority Critical patent/CN110097159B/zh
Publication of CN110097159A publication Critical patent/CN110097159A/zh
Application granted granted Critical
Publication of CN110097159B publication Critical patent/CN110097159B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K19/00Record carriers for use with machines and with at least a part designed to carry digital markings
    • G06K19/06Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code
    • G06K19/06009Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking
    • G06K19/06046Constructional details
    • G06K19/06075Constructional details the marking containing means for error correction
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/14Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation using light without selection of wavelength, e.g. sensing reflected white light
    • G06K7/1404Methods for optical code recognition
    • G06K7/1408Methods for optical code recognition the method being specifically adapted for the type of code
    • G06K7/14172D bar codes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/14Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation using light without selection of wavelength, e.g. sensing reflected white light
    • G06K7/1404Methods for optical code recognition
    • G06K7/146Methods for optical code recognition the method including quality enhancement steps
    • G06K7/1473Methods for optical code recognition the method including quality enhancement steps error correction

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Health & Medical Sciences (AREA)
  • Electromagnetism (AREA)
  • General Health & Medical Sciences (AREA)
  • Toxicology (AREA)
  • Artificial Intelligence (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Quality & Reliability (AREA)
  • Storage Device Security (AREA)

Abstract

本发明公开了一种基于汉明码的QR码认证方法及系统,包括步骤:步骤S1、将QR码信息进行编码以生成初步QR码;步骤S2、将所述初步QR码中的数据模块进行分组;步骤S3、将(7,4)汉明纠错机制将3比特认证信息嵌入到所述初步QR码中得到最终的模块矩阵;步骤S4、对所述终的模块矩阵进行掩模操作;步骤S5、对QR码的信息进行认证。本发明不仅抗打印拍照,还具有信息容量大的特点。本发明方法中,通过(7,4)汉明码修改模块矩阵中的模块嵌入认证信息。在固定的QR码纠错级别下,本发明能够嵌入的更多的认证信息。

Description

一种基于汉明码的QR码安全认证方法及系统
技术领域
本发明涉及安全认证领域,具体涉及一种基于汉明码的QR码安全认证方法及系统。
背景技术
随着移动互联网时代的到来,以“互联网+”为驱动的信息化产业发展取得了重大的突破。作为互联网时代最具标志性的产物,QR码凭借其线上-线下信息对接的优势打破了原产业营销模式约束,促进了传统产业结构向“互联网+”产业的变革。如今,QR码的用途越来越广泛。在电子商务领域,扫码支付已经逐步取代了传统的现金支付模式,这种新型的支付方式正在改变着人们的消费习惯;在移动社交领域,越来越多的社交软件像微信、QQ等都通过QR码扫码来获得用户信息和分享资源;在运输物流领域,交通运输部门通过QR码来对货物的运输进行管理,邮政部门通过QR码对邮政包裹或物流信息进行实时追踪。
QR码为我们的生活带来便利的同时,随之而来的是一系列安全隐患。近年来有关QR码的诈骗事件层出不穷。主要原因是QR码采用国际通用的编解码技术标准,制作简单,且QR码由杂乱无章的黑白模块组成,无法用人眼区分,从外观上并不能判断其安全性。而公众对于QR码普遍缺乏安全防范意识,习惯于随手扫一扫来获得信息。这就更加方便了不法分子对QR码进行各种非法操作。攻击者通过篡改QR码诱导用户打开钓鱼链接,导致用户的个人信息、银行账号、密码的泄露。
公开号为CN 103516404 A的发明专利公开了一种数据传输方法,包括:发送端设备将待传输的数据进行编码,生成N帧适于显示为图形的第一编码数据,每一帧第一编码数据中包含其相应的流水号,N为正整数;在所述发送端设备连续显示每一帧第一编码数据;接收端设备连续采集所述发送端设备显示的第一编码数据,并从采集到的每一帧第一编码数据中提取相应的流水号;若提取的所有流水号是连续的,则由所述接收端设备对采集到的第一编码数据进行解码,以得到所述数据。若提取的所有流水号是非连续,则由所述接收端设备对采集到的第一编码数据进行校验纠错。所述校验纠错包括奇偶校验位纠错、汉明码校验纠错、CRC校验纠错中的至少一种。虽然其提及了采用汉明码对编码数据进行校验纠错,但是其是基于流水号是否连续判断编码数据是否正确,即是结合多个编码数据判断编码数据是否丢失,而不能防止单个QR码的非法操作。
故,针对现有技术的缺陷,如何实现QR码的安全认证是本领域亟待解决的问题。
发明内容
本发明的目的是针对现有技术的缺陷,提供了一种基于汉明码的QR码认证方法及系统,在保证QR码解码稳定性的情况下,使QR码具备认证功能。该方法在认证信息嵌入时,通过修改QR码的一个模块,达到3个比特信息的嵌入,大幅度增加了认证信息的负载量。同时,认证信息在QR码的生成过程中嵌入,嵌入位置通过密钥随机生成,且在信息嵌入完成后,对QR码进行掩码操作,防止由于验证信息的嵌入而使QR码中黑白模块分配不均匀,也进一步加强了认证信息的隐蔽性。
为了实现以上目的,本发明采用以下技术方案:
一种基于汉明码的QR码认证方法,包括步骤:
步骤S1、将QR码信息进行编码以生成初步QR码;
步骤S2、将所述初步QR码中的数据模块进行分组;
步骤S3、将(7,4)汉明纠错机制将3比特认证信息嵌入到所述初步QR码中得到最终的模块矩阵;
步骤S4、对所述终的模块矩阵进行掩模操作;
步骤S5、对QR码的信息进行认证。
进一步的,所述步骤S1具体为:
步骤S1.1、数据分析:对QR码信息进行分析,确定相应的编码字符类型,选择合适的错误检测和纠正级别;
步骤S1.2、数据编码:将数据字符转换为位流;
步骤S1.3、纠错编码:根据QR码的版本和纠错等级确定QR码所使用的RS码制;
步骤S1.4、码字填充:在规格确定的条件下,将上面产生的序列按次序放入分块中。
进一步的,所述步骤S3具体为:
步骤S3.1、通过密钥Key随机选择数据模块组;
步骤S3.2、划分认证信息;
步骤S3.3、嵌入认证信息嵌入;
步骤S3.4、重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时停止信息嵌入。
进一步的,所述步骤S5具体为:
步骤S5.1、去除掩码:扫描QR码去掉掩码信息,得到模块矩阵;
步骤S5.2、分组提取认证信息;
步骤S5.3、合成认证信息:重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时信息提取完毕,将提取的信息拼接合成最终的认证信息;通过检测提取的认证信息是否正确判断QR码是否存在篡改和替换。
进一步的,所述步骤S3.3具体为:
计算校验子向量
Figure BDA0002044632200000031
其中,Sx为3比特信息,Dx为随机选择数据模块组中,H为奇偶校验矩阵;
将所述校验子向量与奇偶校验矩阵H进行比对,当与H的第i列信息相同,则通过修改Dx中的第i位信息将Sx嵌入到Dx中。
进一步的,所述步骤S5.2具体为:
将去除掩码得到的模块矩阵中的模块以7个为一组划分为多个组存放在待选区中,使用密钥Key在待选区中选择一个模块组,记为Dy;在Dy中提取3比特的验证信息Sy=(s1,s2,s3),计算方法如下:
Sy=(H×Dy T)T
相应的,还提供一种基于汉明码的QR码认证系统,包括:
编码模块,用于将QR码信息进行编码以生成初步QR码;
分组模块,用于将所述初步QR码中的数据模块进行分组;
嵌入模块,用于将认证信息嵌入到所述初步QR码中得到最终的模块矩阵;
掩模模块,用于对所述终的模块矩阵进行掩模操作;
认证模块,用于对QR码的信息进行认证。
进一步的,所述所述编码模块包括:
数据分析模块,用于对QR码信息进行分析,确定相应的编码字符类型,选择合适的错误检测和纠正级别;
数据编码模块,用于将数据字符转换为位流;
纠错编码模块,用于根据QR码的版本和纠错等级确定QR码所使用的RS码制;
码字填充模块,用于在规格确定的条件下,将上面产生的序列按次序放入分块中。
进一步的,所述嵌入模块包括:
选择模块,用于随机选择数据模块组;
划分模块,用于划分认证信息;
认证信息嵌入模块,用于嵌入认证信息嵌入;
循环处理模块,用于重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时停止信息嵌入。
进一步的,所述认证模块包括:
去除掩码模块,用于扫描QR码去掉掩码信息,得到模块矩阵;
认证信息提取模块,用于分组提取认证信息;
认证信息合成模块,用于重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时信息提取完毕,将提取的信息拼接合成最终的认证信息,通过检测提取的认证信息是否正确判断QR码是否存在篡改和替换。
本发明的有益效果为:
(1)将初步QR码的数据模块进行分组,通过修改一个模块进行3比特认证信息的嵌入。在QR码纠错能力固定的情况下,大大提高了认证信息的嵌入量。
(2)使用密钥随机选择认证信息的嵌入位置,并在认证信息嵌入完成之后添加掩码,使黑白模块在QR码中均匀分布。进一步增加了认证信息的隐蔽性。
附图说明
图1是QR码安全认证方法流程图;
图2是认证信息嵌入过程流程图;
图3是实验结果示意图;
图4是认证信息提取过程流程图;
图5是QR码安全认证系统结构图。
具体实施方式
以下通过特定的具体实例说明本发明的实施方式,本领域技术人员可由本说明书所揭露的内容轻易地了解本发明的其他优点与功效。本发明还可以通过另外不同的具体实施方式加以实施或应用,本说明书中的各项细节也可以基于不同观点与应用,在没有背离本发明的精神下进行各种修饰或改变。需说明的是,在不冲突的情况下,以下实施例及实施例中的特征可以相互组合。
需要说明的是,以下实施例中所提供的图示仅以示意方式说明本发明的基本构想,遂图式中仅显示与本发明中有关的组件而非按照实际实施时的组件数目、形状及尺寸绘制,其实际实施时各组件的型态、数量及比例可为一种随意的改变,且其组件布局型态也可能更为复杂。
下面结合附图和具体实施例对本发明作进一步说明,但不作为本发明的限定。
实施例一
如图1所示,本实施例提出了一种基于汉明码的QR码认证方法,包括:
步骤S1、将QR码信息进行编码以生成初步QR码;
本发明中,认证信息在初步QR码中嵌入。因此,在潜入认证信息前,需要生成初步QR码,具体包括:
步骤S1.1、数据分析:对QR码信息进行分析,确定相应的编码字符类型,选择合适的错误检测和纠正级别;
具体地,QR码设有1到40的不同版本(种类),每个版本都具备固有的码元结构(码元数)。码元是指构成QR码的方形黑白点。“码元结构”是指二维码中的码元数。从版本1(21码元×21码元)开始,在纵向和横向各自以4码元为单位递增,一直到版本40(177码元×177码元)。
QR码具有“纠错功能”。即使编码变脏或破损,也可自动恢复数据。这一“纠错能力”具备4个级别,用户可根据使用环境选择相应的级别。调高级别,纠错能力也相应提高,但由于数据量会随之增加,编码尺寸也也会变大。QR码的各个版本结合数据量、字符类型和纠错级别,均设有相对应的最多输入字符数。也就是说,如果增加数据量,则需要使用更多的码元来组成QR码,QR码就会变得更大。在规格一定的条件下,纠错等级越高其真实数据的容量越小。
例如,需要输入的数据为100位的数字时,选定步骤为:假设要输入的数据种类为“数字”;从“L”“M”“Q”“H”中选择纠错级别;先从数字列找出数字为100以上且接近100的,其次找出纠错级别“M”,两者交叉的部分就是最佳版本。
步骤S1.2、数据编码:将数据字符转换为位流;
具体地,每8位一个码字,整体构成一个数据的码字序列。当需要进行模式转换时,在新的模式段开始前增加模式指示符完成模式转换。在数据序列后面加入终止符。将产生的位流分为每8比特一个码字,当不足8比特时,用填充码字补充。
步骤S1.3、纠错编码:根据QR码的版本和纠错等级确定QR码所使用的RS码制;
具体地,数据码字按规则分块,根据纠错等级和分块的码字,产生纠错码字,并把纠错码字加入到数据码字序列后面,成为一个新的序列。
在二维码规格和纠错等级确定的情况下,其实它所能容纳的码字总数和纠错码字数也就确定了,比如:版本10,纠错等级时H时,总共能容纳346个码字,其中224个纠错码字。
步骤S1.4、码字填充:在规格确定的条件下,将上面产生的序列按次序放入分块中。
具体地,按规定把数据分块,然后对每一块进行计算,得出相应的纠错码字区块,把纠错码字区块按顺序构成一个序列,添加到原先的数据码字序列后面。
步骤S2、将所述初步QR码中的数据模块进行分组;
本发明中,对数据模块进行分组是为了实现认证信息的嵌入。本申请不对汉明码进行限定。为了更好地说明本申请的实施方案,本实施例采用(7,4)汉明码进行说明。
将模块以7个为一组划分为多个组放入备选区中,并对这些组进行编号,记Di为第i组数据信息,Di=(d1 d2 d3 d4 d5 d6 d7)。每一组中,白色模块对应信息0,黑色模块对应信息1。
步骤S3、将认证信息嵌入到所述初步QR码中得到最终的模块矩阵;
如图2所述,具体步骤如下:
步骤S3.1、随机选择数据模块组;
具体地,本发明通过密钥Key在备选区中的数据模块组中随机选择一个数据模块组,选择的模块组记为Dx
步骤S3.2、划分认证信息;
采用(7,4)汉明码时,将认证信息M以3比特一组进行划分M={S1,S2...Sn},待嵌入的3比特信息记为Sx=(S1,S2,S3)。
步骤S3.3、嵌入认证信息嵌入
具体地,根据(7,4)汉明纠错机制将3比特信息嵌入到Dx中。
例如Sx=(0,1,0),Dx=(0,1,1,1,0,1,0)。H为奇偶校验矩阵,如下所示:
Sx=(0 1 0),Dx=(0 1 1 1 0 1 0),
Figure BDA0002044632200000081
计算得到校验子向量z=(001);计算如下:
Figure BDA0002044632200000082
Figure BDA0002044632200000083
与奇偶校验矩阵H进行比对,发现与H的第1列信息相同,说明通过修改Dx中的第1位信息即修改d1可以将Sx嵌入到Dx中,修改后Dx=(1 1 1 1 0 1 0)。
认证信息嵌入时,对QR码模块的修改量不能超过QR码的最大纠错容量,否则,QR码将不能继续解码。记tc为QR码的最大纠错容量。更改模块矩阵T中相应的模块值,更改完成后将Dx从待选区域中移除。并更新tc=tc-1。
步骤S3.4、重复嵌入认证信息,直到tc=0或者是待选区中没有数据组时停止信息嵌入。得到最终的模块矩阵T'。
步骤S4、对所述终的模块矩阵进行掩模操作;
具体地,在T'构造完成后,通过掩码对整个矩阵进行掩模操作,使QR码图像中白色模块和黑色模块以最优的比例分布。
经过上述操作后,可以生成带有认证信息的QR码,如图3所示。QR码版本为5-L。QR码信息P为“QR Code”,验证信息M为“QR Code Steganography Mechanism...”。如图3(a)所示,T还未添加掩码,不能直接扫码。然后,将认证信息嵌入到T中得到最终的模块矩阵T',如图3(b)所示,同样T'也不能直接扫码。最后,添加掩码,生成最终带认证信息的QR码,如图3(c)所示。可以直接扫码得到QR码信息P。认证信息M的提取需要获得密钥Key,并通过特定的解码软件解码获得。
步骤S5、对QR码的信息进行认证。
在对QR码进行安全认证时,通过扫码获取相应的QR码信息,并基于认证码对QR码的信息进行认证。具体步骤如图4所示。
步骤S5.1、去除掩码:扫描QR码去掉掩码信息,得到模块矩阵;
步骤S5.2、分组提取认证信息;
具体地,将去除掩码得到的模块矩阵T'中的模块以7个为一组划分为多个组存放在待选区中。使用密钥Key在待选区中选择一个模块组,记为Dy。在Dy中提取3比特的验证信息Sy=(s1,s2,s3),如Dy=(1 1 1 1 0 1 0),计算得到Sy=(0 1 0),Sy的计算方法如下:
Figure BDA0002044632200000091
嵌入完成后将Dy从待选区域中移除。
步骤S5.3、合成认证信息:重复嵌入认证信息,直到tc=0或者是待选区中没有数据组时信息提取完毕,将提取的信息拼接合成最终的认证信息M'={S1,S2...Sn}。通过检测提取的认证信息是否正确判断QR码是否存在篡改和替换。
本发明中,认证信息的最大嵌入容量Cs为达到QR码最大纠错容量tc时,可以嵌入的信息量。在计算认证信息的最大嵌入容量时,将T中的数据模块以每7个为一组放入待选区中,QR码纠错级别不同,数据负载Sc(即:T中的数据模块数量)也不同。在信息嵌入的过程中,当有模块信息发生改变,Cs=Cs-1。当Cs=0或者是待选区中没有数据对时停止信息嵌入,此时已嵌入的信息容量就是本章算法在该QR码版本下的信息最大嵌入容量Cs。本发明中,认证信息的最大嵌入容量由QR码的纠错容量和数据负载共同决定。
实施例二
如图5所示,本实施例提出了一种基于汉明码的QR码认证系统,包括:
编码模块,用于将QR码信息进行编码以生成初步QR码;
分组模块,用于将所述初步QR码中的数据模块进行分组;
嵌入模块,用于将认证信息嵌入到所述初步QR码中得到最终的模块矩阵;
掩模模块,用于对所述终的模块矩阵进行掩模操作;
认证模块,用于对QR码的信息进行认证。
本发明中,认证信息在初步QR码中嵌入。因此,在潜入认证信息前,需要生成初步QR码,编码模块具体包括:
数据分析模块,用于对QR码信息进行分析,确定相应的编码字符类型,选择合适的错误检测和纠正级别;
数据编码模块,用于将数据字符转换为位流;
纠错编码模块,用于根据QR码的版本和纠错等级确定QR码所使用的RS码制;
码字填充模块,用于在规格确定的条件下,将上面产生的序列按次序放入分块中。
嵌入模块具体实现包括:
选择模块,用于随机选择数据模块组;
划分模块,用于划分认证信息;
认证信息嵌入模块,用于嵌入认证信息嵌入;
循环处理模块,用于重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时停止信息嵌入。
所述认证模块具体包括:
去除掩码模块,用于扫描QR码去掉掩码信息,得到模块矩阵;
认证信息提取模块,用于分组提取认证信息;
认证信息合成模块,用于重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时信息提取完毕,将提取的信息拼接合成最终的认证信息,通过检测提取的认证信息是否正确判断QR码是否存在篡改和替换。
值得注意的是,本实施例各模块的实现与实施例一相同,在此不再赘述。
本发明在保证QR码解码稳定性的情况下,使QR码具备认证功能。该方法在认证信息嵌入时,通过修改QR码的一个模块,达到3个比特信息的嵌入,大幅度增加了认证信息的负载量。同时,认证信息在QR码的生成过程中嵌入,嵌入位置通过密钥随机生成,且在信息嵌入完成后,对QR码进行掩码操作,防止由于验证信息的嵌入而使QR码中黑白模块分配不均匀,也进一步加强了认证信息的隐蔽性。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。

Claims (6)

1.一种基于汉明码的QR码认证方法,其特征在于,包括步骤:
步骤S1、将QR码信息进行编码以生成初步QR码;
步骤S2、将所述初步QR码中的数据模块进行分组;将数据模块以7个为一组划分为多个组放入备选区中,并对这些组进行编号,记Di为第i组数据信息,Di=(d1 d2 d3 d4 d5 d6d7);每一组中,白色模块对应信息0,黑色模块对应信息1;
步骤S3、将(7,4)汉明纠错机制将3比特认证信息嵌入到所述初步QR码中得到最终的模块矩阵;
步骤S4、对所述最终的模块矩阵进行掩模操作;
步骤S5、对QR码的信息进行认证;
步骤S3具体为:
步骤S3.1、通过密钥Key随机选择数据模块组:通过密钥Key在备选区的数据模块组中随机选择一个数据模块组,选择的模块组记为Dx
步骤S3.2、划分认证信息:采用(7,4)汉明码时,将认证信息M以3比特一组进行划分M={S1,S2...Sn},待嵌入的3比特信息记为Sx=(S1,S2,S3);
步骤S3.3、嵌入认证信息嵌入:根据(7,4)汉明纠错机制将3比特信息嵌入到Dx中;
步骤S3.4、重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时停止信息嵌入;
步骤S5具体为:
步骤S5.1、去除掩码:扫描QR码去掉掩码信息,得到模块矩阵;
步骤S5.2、分组提取认证信息;
步骤S5.3、合成认证信息:重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时信息提取完毕,将提取的信息拼接合成最终的认证信息;通过检测提取的认证信是否正确判断QR码是否存在篡改和替换。
2.根据权利要求1所述的QR码认证方法,其特征在于,步骤S1具体为:
步骤S1.1、数据分析:对QR码信息进行分析,确定相应的编码字符类型,选择合适的错误检测和纠正级别;
步骤S1.2、数据编码:将数据字符转换为位流;
步骤S1.3、纠错编码:根据QR码的版本和纠错等级确定QR码所使用的RS码制;
步骤S1.4、码字填充:在规格确定的条件下,将上面产生的序列按次序放入分块中。
3.据权利要求1所述的QR码认证方法,其特征在于,步骤S3.3具体为:
计算校验子向量
Figure FDA0003777406900000021
其中,Sx为3比特信息,Dx为随机选择数据模块组中,H为奇偶校验矩阵;
将所述校验子向量与奇偶校验矩阵H进行比对,当与H的第i列信息相同,则通过修改Dx中的第i位信息将Sx嵌入到Dx中。
4.据权利要求3所述的QR码认证方法,其特征在于,步骤S5.2具体为:
将去除掩码得到的模块矩阵中的模块以7个为一组划分为多个组存放在待选区中,使用密钥Key在待选区中选择一个模块组,记为Dy;在Dy中提取3比特的验证信息Sy=(s1,s2,s3),计算方法如下:
Sy=(H×Dy T)T
5.一种基于汉明码的QR码认证系统,其特征在于,包括:
编码模块,用于将QR码信息进行编码以生成初步QR码;
分组模块,用于将所述初步QR码中的数据模块进行分组;将数据模块以7个为一组划分为多个组放入备选区中,并对这些组进行编号,记Di为第i组数据信息,Di=(d1 d2 d3 d4 d5d6 d7);每一组中,白色模块对应信息0,黑色模块对应信息1;
嵌入模块,用于将认证信息嵌入到所述初步QR码中得到最终的模块矩阵;嵌入模块具体如下:通过密钥Key在备选区的数据模块组中随机选择一个数据模块组,选择的模块组记为Dx;采用(7,4)汉明码,将认证信息M以3比特一组进行划分M={S1,S2...Sn},待嵌入的3比特信息记为Sx=(S1,S2,S3);根据(7,4)汉明纠错机制将3比特信息嵌入到Dx中;重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时停止信息嵌入;
掩模模块,用于对所述最终的模块矩阵进行掩模操作;
认证模块,用于对QR码的信息进行认证;
所述嵌入模块包括:
选择模块,用于随机选择数据模块组;
划分模块,用于划分认证信息;
认证信息嵌入模块,用于嵌入认证信息嵌入;
循环处理模块,用于重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时停止信息嵌入;
所述认证模块包括:
去除掩码模块,用于扫描QR码去掉掩码信息,得到模块矩阵;
认证信息提取模块,用于分组提取认证信息;
认证信息合成模块,用于重复嵌入认证信息,直到最大纠错容量或者是待选区中没有数据组时信息提取完毕,将提取的信息拼接合成最终的认证信息,通过检测提取的认证信息是否正确判断QR码是否存在篡改和替换。
6.根据权利要求5所述的QR码认证系统,其特征在于,所述编码模块包括:
数据分析模块,用于对QR码信息进行分析,确定相应的编码字符类型,选择合适的错误检测和纠正级别;
数据编码模块,用于将数据字符转换为位流;
纠错编码模块,用于根据QR码的版本和纠错等级确定QR码所使用的RS码制;码字填充模块,用于在规格确定的条件下,将上面产生的序列按次序放入分块中。
CN201910353278.XA 2019-04-29 2019-04-29 一种基于汉明码的qr码安全认证方法及系统 Active CN110097159B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910353278.XA CN110097159B (zh) 2019-04-29 2019-04-29 一种基于汉明码的qr码安全认证方法及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910353278.XA CN110097159B (zh) 2019-04-29 2019-04-29 一种基于汉明码的qr码安全认证方法及系统

Publications (2)

Publication Number Publication Date
CN110097159A CN110097159A (zh) 2019-08-06
CN110097159B true CN110097159B (zh) 2022-09-23

Family

ID=67446228

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910353278.XA Active CN110097159B (zh) 2019-04-29 2019-04-29 一种基于汉明码的qr码安全认证方法及系统

Country Status (1)

Country Link
CN (1) CN110097159B (zh)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112507747B (zh) * 2020-12-10 2024-04-19 北京爱创科技股份有限公司 一种追溯码扫描的装置及方法
CN112906844B (zh) * 2021-03-25 2022-05-13 绍兴聚量数据技术有限公司 基于(3,1)汉明码的二维码秘密共享、还原方法及装置
CN114742910B (zh) * 2022-04-20 2024-05-31 浙江沃得威数字技术服务有限公司 图像生成方法、存储介质及计算机终端

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5646997A (en) * 1994-12-14 1997-07-08 Barton; James M. Method and apparatus for embedding authentication information within digital data
CN102983938A (zh) * 2012-11-13 2013-03-20 中国人民解放军72671部队 基于qr码的无反馈单向数据传输方法及装置
JP2014085777A (ja) * 2012-10-23 2014-05-12 Terrara Code Research Institute Inc 二次元コード、二次元コードの生成方法、及び二次元コードの読取方法
CN108491747A (zh) * 2018-02-06 2018-09-04 南京风力舰信息技术有限公司 一种融合图像后美化qr码的方法

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1395986A1 (en) * 2001-05-15 2004-03-10 Koninklijke Philips Electronics N.V. Embedding auxiliary data in an information signal
US7895502B2 (en) * 2007-01-04 2011-02-22 International Business Machines Corporation Error control coding methods for memories with subline accesses
CN104376356A (zh) * 2014-12-02 2015-02-25 合肥城市云数据中心有限公司 一种带有加密功能的二维码生成方法
CN106650869B (zh) * 2016-10-18 2020-02-07 重庆文理学院 一种基于二维码的信息隐藏方法
CN106815544B (zh) * 2017-01-16 2019-05-10 武汉大学 一种基于二维码的信息隐藏方法
CN107169395A (zh) * 2017-06-20 2017-09-15 重庆大学 一种更加安全的qr码生成及读取方法

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5646997A (en) * 1994-12-14 1997-07-08 Barton; James M. Method and apparatus for embedding authentication information within digital data
JP2014085777A (ja) * 2012-10-23 2014-05-12 Terrara Code Research Institute Inc 二次元コード、二次元コードの生成方法、及び二次元コードの読取方法
CN102983938A (zh) * 2012-11-13 2013-03-20 中国人民解放军72671部队 基于qr码的无反馈单向数据传输方法及装置
CN108491747A (zh) * 2018-02-06 2018-09-04 南京风力舰信息技术有限公司 一种融合图像后美化qr码的方法

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
Jisha Thomas ; R.H Goudar."Multilevel Authentication using QR code based watermarking with mobile OTP and Hadamard transformation".《IEEE》.2018, *
基于QR码和量化DCT的遥感影像数字水印算法;王潇等;《地理与地理信息科学》;20171130(第06期);第19-24页 *
基于二维汉明码结构的闪存纠错存储系统;余辉龙等;《微电子学与计算机》;20180305(第03期);第1-3页 *

Also Published As

Publication number Publication date
CN110097159A (zh) 2019-08-06

Similar Documents

Publication Publication Date Title
CN110097159B (zh) 一种基于汉明码的qr码安全认证方法及系统
CN105447546B (zh) 可嵌入大比例图形的二维码及其编码和解码方法和设备
Kieseberg et al. QR code security
CN106650869B (zh) 一种基于二维码的信息隐藏方法
CN108229596A (zh) 组合二维码、电子证书载体、生成、识读装置及方法
CN101086761A (zh) 高效信息点阵图形及其生成和解码方法
CN104143200B (zh) 一种图像附加信息的边框型编码与智能识别方法
CN107392583B (zh) 一种二维码图形数据生成方法和装置
US8297510B1 (en) Mathematical method of 2D barcode authentication and protection for embedded processing
CN105825257A (zh) 基于二维条码的信息隐藏与隐藏信息提取方法及系统
CN103632179B (zh) 三维条码的编码和解码方法及装置
CN109816077A (zh) 一种二维码信息的隐藏方法、装置、电子设备及存储介质
CN110516775B (zh) 基于qr码用户秘密信息隐藏方法
CN111737713B (zh) 基于可视密码的二维码秘密共享方法
CN108491913B (zh) 一种含密美化qr码认证的方法
AU2010257220B2 (en) Data block offset encoding method for coordinates
CN107203798B (zh) 一种限制访问型图形背景二维码的生成和识别方法
Kuribayashi et al. Aesthetic QR code based on modified systematic encoding function
CN117273044A (zh) 一种点阵图、点阵图构建方法及识别点阵图的方法
CN112288617A (zh) 基于马赛克拼图的信息隐藏及恢复方法、设备及介质
CN115334317A (zh) 一种信息处理方法、装置及设备
CN111626393A (zh) 一种基于qr码和回转变换的图像加密方法及系统
CN109840574B (zh) 一种二维码信息的隐藏方法、装置、电子设备及存储介质
CN113557529B (zh) 混合二维条码阅读器
CN112329599A (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
GR01 Patent grant
GR01 Patent grant