- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
“备”则“倍” 有准备、有规划的人生更精彩! * 公钥密码体制——背包公钥密码体制 背包体制 构造公钥体制的原理 主要内容 一、背包体制 下面以背包问题为例来介绍如何构造公钥密码体制。 背包问题:给定一堆物品,重量各不相同,能否将这些物品放入一个背包中,使之等于一个给定的重量? 例:这些物品的重量分别为:1,5,6,11,14,20。问能否组成重量分别为22和24的背包? 直观上: c表示背包的大小,每个数字ai表示能装到该背包中的物品的大小。问题是选择一些物品,使得它们正好填满这个背包。其中xi为1表示物品在背包中,xi为0表示物品不在背包中。 1、背包问题的数学描述 给定 n个正整数的集合A a1, a2, …,an 及正整数c,求0、1向量x x1, x2, …,xn ,使得: 其中a a1, a2, …,an 称为背包向量。 原则上,只要搜索集合A a1, a2, …,an 的所有子集并检验其元素之和是否为c,则总可以决定此背包问题是否有解,若有解就一定能够找到。 但注意到A的子集个数为: 背包问题是NP完全问题。 单向函数: 由集合A和0、1向量x很容易求得c; 但由集合A和c却很难求得0、1向量x 1、背包问题的数学描述 背包密码算法的思想是将消息编码为背包问题的解。明文分组长度等于堆中物品个数,且明文位与 0、1向量x相对应,密文是计算得到的和值。 例:设背包向量为:A 1,5,6,11,14,20 明文:111001 010110 100101 密文:1+5+6+20 5+11+14 1+11+20 32 30 32 解密时,合法接收者也必须解背包问题;且不同明文有可能加密成同一密文。这不符合公钥密码体制的要求。 1、背包问题的数学描述 定义:若对 均有 则称向量A a1, a2, …,an 为超递增背包向量,相应的背包问题称为超递增背包问题。 2、利用超递增背包构造公钥密码体制 超递增背包问题是易解的。 超递增背包中的每一项都大于它之前所有项之和。 给定超递增背包向量A a1,a2,…,an ,对任意n比特明文m x1, x2, …,xn ,由a得到密文 任何用户收到c后,都可容易地求得m: 首先比较c和an,若 ,则an不在该背包中xn 0;若 ,则an必在该背包中xn 1,因为所有其它分量的和a1+a2+…+an-1 an ,记c’ c-an 。对c’和an-1重复上述过程,当到达a1时,整个过程结束。若变为0,则有唯一解m ;否则无解。 例:背包A 2,3,6,13,27,52 ,c 70 该背包的解为:110101 2、利用超递增背包构造公钥密码体制 一般的背包问题是困难问题,而超递增背包问题是易解的。Merkle-Hellman公钥密码算法就利用这一性质。保密密钥是一个超递增背包向量A,公开密钥是A经过“置乱” 后的一般背包向量。 Merkle-Hellman公钥密码算法: 1 选取一个超递增背包A a1, a2, …,an 和模M 使M a1+a2+…+an ; 2 取w使 w,M 1, 并求满足ww-1modM 1的w-1; 3 构造背包向量b b1,b2,…,,bn 且bi waimod M ; 4 公开密钥: b b1, b2, …,bn 保密密钥: A a1, a2, …,an 、M 和 w 2、利用超递增背包构造公钥密码体制 5 加密 设明文m m1, m2, …,mn ; mi 0,1 6 脱密 收到密文c后,计算 s w-1c modM m1a1+ m2a2+……+mnan 收方由s利用A的超递增特性可求出明文m。 由于w是保密的,非法用户不能由c还原m。 密文c m1b1+ m2b2+ …+mnbn 2、利用超递增背包构造公钥密码体制 例:设M 89,A 2,6,9,19,41 ,取w 13求w-1,b,对明文 m 10101 加密并脱密。 解:由Euclid算法可求出w-1 48 mod89。 则b (26,78,28,69,88) 加密:c 26+28+88 142 脱密:计算s cw-1mod89 52 52 41 则 m5 1 52-41 11 19 则 m4 0 11 9 则 m3 1 11-9 2 6 则 m2 0 2 2 则 m1 1 2、利用超递增背包构造公钥密码体制 1 选取一个困难问题P; 2 选择困难问题P一个容易子问题PEasy,它应该是多项式时间问题,最好是线性时间问题; 3 “置乱”问题PEasy使所得问题PS 是困难问题; 4 公开PS ,并描述如何将它用作一个加密变换。将Ps逆回到PEasy的信息作为秘密陷门; 5
您可能关注的文档
最近下载
- 特种作业与特种设备作业人员培训课件.pptx VIP
- 22G101 三维彩色立体图集.docx VIP
- DK-金检机说明书(20110823HJ)-2.doc VIP
- SHT 3178-2015- 加油站用埋地钢-玻璃纤维增强塑料双层油罐工程技术规范.pdf VIP
- 特种设备典型事故案例.ppt VIP
- 2025-2026学年鲁科版(五四学制)(三起)(2024)英语四年级上册教学计划及进度表.pdf VIP
- 机器人行业深度报告:行星滚柱丝杠——高精技术集成之作,人形机器人线性关节 -2024-.pdf VIP
- JEDEC JESD47L(中英文对照版).pdf VIP
- 9 天上有颗南仁东星 课件(共28张PPT) 2025-2026统编版八年级语文上册.pptx VIP
- 科普版英语五年级上册单词默写表.docx VIP
文档评论(0)