CN102136906A - 一种快速生成防伪码的加密算法 - Google Patents

一种快速生成防伪码的加密算法 Download PDF

Info

Publication number
CN102136906A
CN102136906A CN2011101112320A CN201110111232A CN102136906A CN 102136906 A CN102136906 A CN 102136906A CN 2011101112320 A CN2011101112320 A CN 2011101112320A CN 201110111232 A CN201110111232 A CN 201110111232A CN 102136906 A CN102136906 A CN 102136906A
Authority
CN
China
Prior art keywords
security code
key
key2
encryption method
place
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
Application number
CN2011101112320A
Other languages
English (en)
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.)
GUIYANG GAOXINHUAMEILONG TECHNOLOGY Co Ltd
Original Assignee
GUIYANG GAOXINHUAMEILONG TECHNOLOGY Co Ltd
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 GUIYANG GAOXINHUAMEILONG TECHNOLOGY Co Ltd filed Critical GUIYANG GAOXINHUAMEILONG TECHNOLOGY Co Ltd
Priority to CN2011101112320A priority Critical patent/CN102136906A/zh
Publication of CN102136906A publication Critical patent/CN102136906A/zh
Pending legal-status Critical Current

Links

Landscapes

  • Storage Device Security (AREA)
  • Lock And Its Accessories (AREA)

Abstract

本发明公开了一种快速生成防伪码的加密算法,该加密算法首先定义一个密钥key1和一个密钥key2,然后通过选定的一种加密方法将key1演变成m个子密钥,再根据生成的防伪码个数选择一个顺序数空间,并将该顺序数空间内的顺序数与一固定质数r相乘,然后与密钥key2通过和运算,得到被加密明文,最后从m个子密钥中随机选取一个密钥,通过选定的一种加密方法将明文加密,再将随机密匙附加在密文的指定位上,即得到防伪码。本发明具有加密强度大、加密速度快等特点,且保证了生成的防伪码稀疏程度有一定的保证,虽然被加密的内容是由顺序数通过简单运算而来,但所生成的密文却是无规则的乱序数。

Description

一种快速生成防伪码的加密算法
技术领域
本发明涉及一种生成防伪码的方法,特别是一种快速生成防伪码的加密算法,属于防伪技术领域。
背景技术
假冒产品不但侵害了广大消费者的利益,扰乱了正常的市场秩序,而且给厂商带来了巨大的经济损失。各生产企业为了保护自己的利益不受假冒产品侵害,大多会在产品上印刷防伪码。消费者在验证产品真假时,只需要刮开防伪码的覆盖层,通过网站、电话、手机短信等形式输入防伪码,经过查询即可得知该产品的真伪结果。目前,生成防伪码的加密算法很多,但大多数加密算法的加密强度不是很理想,加密速度也较慢。
发明内容
本发明所要解决的技术问题在于提供一种加密强度大、加密速度快的快速生成防伪码的加密算法,从而克服上述现有技术的不足。
为解决上述技术问题,本发明采用如下的技术方案:一种快速生成防伪码的加密算法。该加密算法包括以下步骤:
(1)、定义一个n位定长的密钥key1;
(2)、根据生成的防伪码位数w,定义一个q位定长的密钥key2;
(3)、通过选定的一种加密方法A将key1演变成m个定长的子密钥[k(1),k(m)];
(4)、设定生成c个防伪码,选择一个顺序数空间[s(i),s(j)];
(5)、将上述顺序数空间[s(i),s(j)]内的顺序数s(i)到s(j)与一设定的固定质数r相乘,然后与密钥key2通过和运算,得到被加密明文[L(i),L(j)],其计算公式为L=s*r+key2;
(6)、随机选取k(1)到k(m)之间的一个密钥k(rd),通过选定的一种加密方法B将明文[L(i),L(j)]加密后得到密文,再将随机密匙K=rd附加在密文的指定位上,即得到c个防伪码。
上述的快速生成防伪码的加密算法,步骤(2)中密钥key2的位数q=w~(k(m)的位数),即密钥key2的位数q介于防伪码位数w与k(m)的位数之间。
前述的快速生成防伪码的加密算法,在验证防伪码时,需要根据加密算法中定义的key1,key2和r,通过对防伪码的指定位数进行提取,得到加密时使用的随机密匙K,再将其他位根据加密方法B进行逆运算,得到被加密明文L,然后按照公式s=(L-key2)/r经计算得到s,验证s是否属于加密时选择的顺序数空间[s(i),s(j)]即可知道防伪码的真假。
有益效果:与现有技术相比,与现有技术相比,本发明每次对明文的加密都采用随机的密钥,加密强度大,且保证了生成的防伪码稀疏程度有一定的保证。而且本发明的加密速度很快,经测试,在intel酷睿i3的CPU下,生成1000万个防伪码所需时间最多不超过2秒。本发明的算法本身的可变性很高,可以根据需要生成不同位数的防伪码,最重要的是虽然被加密的内容是由顺序数通过简单运算而来,但所生成的密文却是无规则的乱序数。
下面结合具体实施方式对本发明作进一步的说明。
具体实施方式
实施例1。本发明的加密算法包括以下步骤:
(1)、首先定义一个n位定长的密钥key1。假设key1=“012345678901234567890123456789”。
(2)、根据生成的防伪码位数w,定义一个q位定长的密钥key2。假设防伪码位数w=6,q=6,key2=159357;
(3)、通过选定的一种加密方法A将key1演变成m个w位定长的子密钥[k(1),k(m)]。假设选定的加密方法A为:k(m)=CLng(Mid(key1,u,w)),u≤n,其中函数CLng表示将括号中所取字符数字转换成长整型整数,Mid(key1,u,w)表示从key1字符串中的第u位起取出w个字符。取出的的字符位数不应大于明文位数,以保证在步骤(6)的异或运算时生成的数据位数不会大于明文位数。加密方法A可以使用任意方法,其主要目的是密匙重组,因此不应仅限于实例的方法。假设m=1000,w=6,u随机设定。根据加密方法A,假设:
k(1)=CLng(Mid(key1,7,6))=678901
k(2)=CLng(Mid(key1,13,6))=234567
。。。
K(1000)=CLng(Mid(key1,1,6))=012345
(4)、设定生成c个防伪码,选择一个顺序数空间[s(i),s(j)],j>i,j-i=c。假设生成防伪码的个数c=10000,s(i)=101,s(j)=10100。
(5)、将上述顺序数空间[s(i),s(j)]内的顺序数s(i)到s(j)与一设定的固定质数r相乘,然后与密钥key2通过和运算,得到被加密明文[L(i),L(j)],其计算公式为L=s*r+key2。如果设定质数r=5,则:
L(i)=s(i)*r+key2=101*5+159357=159862
L(i+1)=s(i+1)*r+key2=102*5+159357=159867
。。。
L(j)=s(j)*r+key2=10100*5+159357=209857
(6)、随机选取k(1)到k(m)之间的一个密钥k(rd),通过选定的加密方法B将明文[L(i),L(j)]加密后得到密文,再将随机密钥K=rd附加在密文的指定位上,即得到c个防伪码。
假设选定的加密方法B为:Format((L(i)Xor k(rd)),“000000”),其中Format((L(i)Xor k(rd)),“000000”)表示将(L(i)Xor k(rd))定长6位整数,如果整数不足6位,则前面加“0”。假设随机选取的密钥为k(2)=234567,则明文L(i)经加密方法B加密后得到的密文为:Format((L(i)Xor k(2)),“000000”)=Format(159862Xor 234567,“000000”)=123953,再将随机密匙K=2插入密文的第3位,即得到最终防伪码为1223953。依此类推,即可得到c个防伪码。
防伪码验证时,验证的key1,key2,r必须与加密算法中的数据配套。首先通过对防伪码的指定位数进行提取,得到加密时使用的随机密匙K,再将其他位根据选定的加密方法B进行逆运算,得到被加密明文L,然后根据公式s=(L-key2)/r得到s,验证s是否属于加密时的[s(i),s(j)],即可知道防伪码的真假。
本发明中的加密方法A和加密方法B可以是任意方法,实际应用中不局限于上例列举的加密方法。
本发明的实施方式不限于上述实施例,在不脱离本发明宗旨的前提下做出的各种变化均属于本发明的保护范围之内。

Claims (3)

1.一种快速生成防伪码的加密算法,其特征在于:包括以下步骤,
(1)、定义一个n位定长的密钥key1;
(2)、根据生成的防伪码位数w,定义一个q位定长的密钥key2;
(3)、通过选定的一种加密方法A将key1演变成m个定长的子密钥[k(1),k(m)];
(4)、设定生成c个防伪码,选择一个顺序数空间[s(i),s(j)];
(5)、将上述顺序数空间[s(i),s(j)]内的顺序数s(i)到s(j)与一设定的固定质数r相乘,然后与密钥key2通过和运算,得到被加密明文[ L(i),L(j)],其计算公式为L=s*r+key2;
(6)、随机选取k(1)到k(m)之间的一个密钥k(rd),通过选定的一种加密方法B将明文[ L(i),L(j)]加密后得到密文,再将随机密匙K=rd附加在密文的指定位上,即得到c个防伪码。
2.根据权利要求1所述的快速生成防伪码的加密算法,其特征在于:所述的步骤(2)中密钥key2的位数q=w~(k(m)的位数)。
3.根据权利要求1所述的快速生成防伪码的加密算法,其特征在于:验证防伪码时,根据加密算法中定义的key1,key2和r,通过对防伪码的指定位数进行提取,得到加密时使用的随机密匙K,再将其他位根据加密方法B进行逆运算,得到被加密明文L,然后按照公式s=(L-key2)/r经计算得到s,验证s是否属于加密时选择的顺序数空间[s(i),s(j)]即可知道防伪码的真假。
CN2011101112320A 2011-04-29 2011-04-29 一种快速生成防伪码的加密算法 Pending CN102136906A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN2011101112320A CN102136906A (zh) 2011-04-29 2011-04-29 一种快速生成防伪码的加密算法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN2011101112320A CN102136906A (zh) 2011-04-29 2011-04-29 一种快速生成防伪码的加密算法

Publications (1)

Publication Number Publication Date
CN102136906A true CN102136906A (zh) 2011-07-27

Family

ID=44296568

Family Applications (1)

Application Number Title Priority Date Filing Date
CN2011101112320A Pending CN102136906A (zh) 2011-04-29 2011-04-29 一种快速生成防伪码的加密算法

Country Status (1)

Country Link
CN (1) CN102136906A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106548353A (zh) * 2016-09-30 2017-03-29 昆明理工大学 一种商品防伪码生成与验证方法

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1272010A (zh) * 1999-04-28 2000-11-01 富士软件Abc株式会社 加密/解密方法和使用多仿射密钥系统的验证方法及装置
CN101094059A (zh) * 2007-07-13 2007-12-26 南京邮电大学 网络信息广播的加密解密方法
CN101207787A (zh) * 2006-12-22 2008-06-25 南京理工大学 支持用户分级的多媒体数据广播方法
CN101753292A (zh) * 2008-12-15 2010-06-23 汤姆森许可贸易公司 用于链接式加密模式的方法和设备
CN101895390A (zh) * 2010-02-05 2010-11-24 上海复旦天臣新技术有限公司 一种加解密方法、装置及系统

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1272010A (zh) * 1999-04-28 2000-11-01 富士软件Abc株式会社 加密/解密方法和使用多仿射密钥系统的验证方法及装置
CN101207787A (zh) * 2006-12-22 2008-06-25 南京理工大学 支持用户分级的多媒体数据广播方法
CN101094059A (zh) * 2007-07-13 2007-12-26 南京邮电大学 网络信息广播的加密解密方法
CN101753292A (zh) * 2008-12-15 2010-06-23 汤姆森许可贸易公司 用于链接式加密模式的方法和设备
CN101895390A (zh) * 2010-02-05 2010-11-24 上海复旦天臣新技术有限公司 一种加解密方法、装置及系统

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
《清华大学学报(自然科学版)》 20030130 蔡义望等 "综合数字防伪方案" 第91页 1-3 第43卷, 第1期 *
蔡义望等: ""综合数字防伪方案"", 《清华大学学报(自然科学版)》 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106548353A (zh) * 2016-09-30 2017-03-29 昆明理工大学 一种商品防伪码生成与验证方法
CN106548353B (zh) * 2016-09-30 2020-04-07 昆明理工大学 一种商品防伪码生成与验证方法

Similar Documents

Publication Publication Date Title
CN102546181B (zh) 基于密钥池的云存储加解密方法
Mathur A Research paper: An ASCII value based data encryption algorithm and its comparison with other symmetric data encryption algorithms
CN101202623B (zh) 消息验证码产生方法、验证/加密和验证/解密方法
CN103684794A (zh) 一种基于des、rsa、sha-1加密算法的通信数据加解密方法
CN103152362B (zh) 基于云计算的大数据文件加密传输方法
Daemen et al. The first 10 years of advanced encryption
CN103716157A (zh) 分组多密钥加密方法及装置
CN104378198A (zh) 一种基于分组密码体制的语音加密方法
CN105282090A (zh) 一种互联网上防非法访问的公开url加密编码方法
CN103942500A (zh) 基于噪声的哈希密文再加密方法及再加密后的解密方法
CN103824197B (zh) 防伪码生成装置
CN105187418B (zh) 一种弱签名算法
CN104113410A (zh) 一种基于多表加密法的数据加密传输方法及装置
CN106789053A (zh) 随机密文生成方法及系统、解密方法及系统
CN103745427A (zh) 基于迭代振幅-相位恢复算法的图像加密方法
CN105959099A (zh) 一种实现ssr密码加密的方法
Tang et al. A one-time pad encryption algorithm based on one-way hash and conventional block cipher
CN111314270B (zh) 一种基于有效期均匀分布对称算法的数据加密和解密方法
Park et al. Methods for practical whitebox cryptography
Lee et al. Design and evaluation of a block encryption algorithm using dynamic-key mechanism
CN102546152B (zh) 一种实现数据多级加密、解密的方法
Singh et al. Enhancing AES using novel block key generation algorithm and key dependent S-boxes
CN115632765A (zh) 加密方法、解密方法、装置、电子设备及存储介质
CN102136906A (zh) 一种快速生成防伪码的加密算法
CN111314052B (zh) 一种数据加密和解密方法

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C53 Correction of patent of invention or patent application
CB02 Change of applicant information

Address after: 550022, B building, building 9, hi tech Zone, Guiyang hi tech Zone, Guizhou

Applicant after: GUIZHOU ZHUOLIN ANTI-COUNTERFEITING TECHNOLOGY Co.,Ltd.

Address before: 550022, B building, building 9, hi tech Zone, Guiyang hi tech Zone, Guizhou

Applicant before: Guizhou Zhuo Lin hi tech anti-counterfeiting Co.,Ltd.

Address after: 550022, B building, building 9, hi tech Zone, Guiyang hi tech Zone, Guizhou

Applicant after: Guizhou Zhuo Lin hi tech anti-counterfeiting Co.,Ltd.

Address before: 550022, B building, building 9, hi tech Zone, Guiyang hi tech Zone, Guizhou

Applicant before: GUIYANG GAOXIN HUAMEILONG TECHNOLOGY Co.,Ltd.

COR Change of bibliographic data

Free format text: CORRECT: APPLICANT; FROM: GUIZHOU ZHUOLIN HIGH-TECH. ANTI-COUNTERFEITING CO., LTD. TO: GUIZHOU ZHUOLIN ANTI-COUNTERFEITING TECHNOLOGY CO., LTD.

Free format text: CORRECT: APPLICANT; FROM: GUIYANG GAOXINHUA MEILONG TECHNOLOGY CO., LTD. TO: GUIZHOU ZHUOLIN HIGH-TECH. ANTI-COUNTERFEITING CO., LTD.

C12 Rejection of a patent application after its publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20110727