量子安全的Lamport One Time Signature 算法学习

学习Lamport原文链接

复制代码
https://www.btcstudy.org/2025/08/25/quantum-safe-lamport-signatures/

专有名词解释和简写

原文 简写
One Time Signature OTS

原理

前提条件

对于Lamport OTS 算法的原理,需要有一些明确的前提条件。

  1. 假设Lamport 算法使用的加密算法是sha256(但实际上无论用什么hash算法都可以),后续提到的hash 即为这个算法
  2. Lamport OTS 算法不考虑原文是否被加密,即对MSG的操作都是原文
  3. 我们需要规定两个私钥集合A和集合B,两个集合中都含有长度为256位的256个随机数,如下图所示:

这两个集合中含有的随机数就是我们Lamport 算法的私钥,而公钥则是私钥通过hash 运算而来。因此两个私钥集合就会得到对应的两个公钥集合

工作原理

在刚才的前提条件中,我们已经讲解完了在Lamport 算法中密钥是如何生成的。简单来说只是生成了512个随机数,然后对他们做hash,就得到了我们的公钥,原本的随机数则是私钥

签名过程

先提出签名过程总体流程

  1. 将消息(msg message)进行一次hash 操作,这个操作记作h(m) ,得到输出 rsltrslt长度为256bit
  2. 将hash 操作输出的结果rslt 视作一个0和1构成的比特流
  3. 根据rslt 的比特流构成,(这里假设0对应私钥集合A,1对应私钥集合B)从两个私钥集合中取出对应序号的私钥来构成签名,每个私钥作为构成签名的一个数字(number) ,下面引用学习博客中的的一张图更直观的显示签名构建的过程

验签过程

  1. 验签的时候,先对原本的消息M进行一次hash,得到结果table它的大小为256bit,结果与签名构建时的rslt相同
  2. 再对签名S按照number进行划分,对每个number 做一次hash,这次操作为h(number) ,得到的结果的集合为rslt_set ,集合中的元素为h(number)
  3. 这时,我们可以根据table中的bit来判断,每256bit 对应的是哪个一个集合的公钥。将rslt_set 中的元素与对应公钥集合里面的公钥对比,判断它们是否一致。如果一致,则继续往下检查,直到rslt_set中的所有元素都与公钥表中的公钥一致。

如果全都一致,则代表验签通过,否则验签失败

例如,table[0](bit0) = 1,由于table = rslt_set,因此我们需要判断出rslt_set的一个元素要与公钥集合B中的第0个公钥要相同,不然的话,验签就失败了。

弊端

从原理中我们不难发现,由于签名的构造是根据私钥本身来拼凑而成的,每次验签过后,我们就会暴露出50%的私钥。等到下一次验签后,我们最多会暴露出一共75%的私钥。这样下去,我们没有暴露出的私钥就越来越少了

相关推荐
heimeiyingwang14 小时前
【架构实战】VPC网络与跨域通信:构建安全可控的云上网络
网络·安全·架构
代码飞一会儿14 小时前
CTF之通过栈溢出偷出信息
安全
wangl_9214 小时前
Modbus RTU 与 Modbus TCP 深入指南-安全加固方案
网络·网络协议·tcp/ip·安全·tcp·modbus·rtu
S1998_1997111609•X14 小时前
哈希树阻断正常系统通信工程进行函数钩子解析
安全·百度·缓存·哈希算法·量子计算
薛定猫AI15 小时前
【深度解析】Hermes Agent:持久记忆、自学习闭环与桌面化 Autonomous AI 工作流实践
人工智能·学习
老虎062715 小时前
黑马程序员苍穹外卖--学习笔记(苍穹外卖万字总结—重点知识,面试常见问题)超全
笔记·学习·面试
sealaugh3215 小时前
react native(学习笔记第四课) 英语打卡微应用(3)-ocr的文字转化成语音文件(tts)
笔记·学习·react native
小新同学^O^15 小时前
简单学习 --> SpringAOP
java·学习·spring·aop
炽烈小老头16 小时前
【每天学习一点算法 2026/05/10】合并K个排序链表
学习·算法·链表
wuxinyan12316 小时前
大模型学习之路010:RAG 零基础入门教程(第六篇):重排序技术
人工智能·学习·rag