当前位置: 首页 > news >正文

Signature

Signature

题目是:

 import ecdsaimport random​def ecdsa_test(dA,k):​sk = ecdsa.SigningKey.from_secret_exponent(secexp=dA,curve=ecdsa.SECP256k1)sig1 = sk.sign(data=b'Hi.', k=k).hex()sig2 = sk.sign(data=b'hello.', k=k).hex()#不同的kr1 = int(sig1[:64], 16)s1 = int(sig1[64:], 16)s2 = int(sig2[64:], 16)return r1,s1,s2​if __name__ == '__main__':n = 0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141a = random.randint(0,n)flag = 'flag{' + str(a) + "}"b = random.randint(0,n)print(ecdsa_test(a,b))​# (4690192503304946823926998585663150874421527890534303129755098666293734606680, 111157363347893999914897601390136910031659525525419989250638426589503279490788, 74486305819584508240056247318325239805160339288252987178597122489325719901254)

分析代码可以看出,存在随机数重复使用。

具体来说,这段代码中签名的过程中使用了相同的随机数 k 来对不同的消息进行签名。

这种情况下,可以通过分析两个相同 k 值对应的消息签名来恢复私钥 dA。

import sympyfrom hashlib import sha1from Cryptodome.Util.number import long_to_bytes , bytes_to_long​def calculate_private_key(r1, s1, s2, h1, h2, n):# 计算k值k = ((h1 - h2) * sympy.mod_inverse(s1 - s2, n)) % n# 计算私钥dAdA = (sympy.mod_inverse(r1, n) * (k * s1 - h1)) % nreturn dAif __name__ == "__main__":# 定义椭圆曲线的参数n = 0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141# 签名中的r1, s1, s2值r1 = 4690192503304946823926998585663150874421527890534303129755098666293734606680s1 = 111157363347893999914897601390136910031659525525419989250638426589503279490788s2 = 74486305819584508240056247318325239805160339288252987178597122489325719901254h1 = bytes_to_long(sha1(b'Hi.').digest())h2 = bytes_to_long(sha1(b'hello.').digest())private_key = calculate_private_key(r1, s1, s2, h1, h2, n)print(f'flag{{{private_key}}}')---------------------------------------------------------flag{40355055231406097504270940121798355439363616832290875140843417522164091270174}   

椭圆曲线数字签名算法(Elliptic Curve Digital Signature Algorithm,ECDSA)是一种基于椭圆曲线密码学的数字签名算法。它广泛应用于需要确保数据完整性和身份验证的场景中,例如在区块链技术(如比特币)、安全通信协议(如TLS/SSL)等领域。

  1. 基本原理

ECDSA 是一种非对称加密算法,它基于椭圆曲线数学的复杂性来实现数字签名的生成和验证。其核心思想是利用椭圆曲线上的点的加法运算和标量乘法运算,这些运算在数学上是单向的,即很容易进行正向计算,但很难进行逆向求解。

  • 椭圆曲线:椭圆曲线是一种特殊的数学曲线。椭圆曲线上的点具有特殊的代数结构,使得点的加法和标量乘法运算可以高效地实现。

  • 私钥和公钥:在 ECDSA 中,私钥是一个随机生成的大整数 d,公钥是椭圆曲线上的一个点 Q,通过 Q=d×G 计算得到,其中 G是椭圆曲线上的一个基点。

  1. 签名生成过程

签名生成过程主要包括以下步骤:

  1. 选择随机数:签名者选择一个随机整数 k(称为临时私钥),并计算椭圆曲线上的点 R=k×G。

  2. 计算 r 和 s

    • r 是点 R 的 x 坐标对模数 n(椭圆曲线的阶)取模的结果。

    • s=k−1(H(m)+d⋅r)mod n,其中 H(m) 是消息 m 的哈希值,k−1 是 k 的模逆元。

  3. 输出签名:签名由 (r,s) 组成。

  1. 签名验证过程

验证签名的过程主要包括以下步骤:

  1. 计算 w:验证者计算 w=s−1mod n。

  2. 计算 u1 和 u2

    • u1=H(m)⋅w mod n

    • u2=r⋅w mod n

  3. 计算点 R′:计算 R′=u1×G+u2×Q。

  4. 验证 r:检查 r 是否等于 R′ 的 x 坐标对模数 n 取模的结果。如果相等,则签名验证通过,否则验证失败。

http://www.lryc.cn/news/530486.html

相关文章:

  • 93,【1】buuctf web [网鼎杯 2020 朱雀组]phpweb
  • 笔灵ai写作技术浅析(四):知识图谱
  • Chromium132 编译指南 - Android 篇(四):配置 depot_tools
  • 使用真实 Elasticsearch 进行高级集成测试
  • SQL进阶实战技巧:如何分析浏览到下单各步骤转化率及流失用户数?
  • 机器学习--概览
  • 低代码系统-产品架构案例介绍、炎黄盈动-易鲸云(十二)
  • Electricity Market Optimization 探索系列(二)
  • OpenAI 实战进阶教程 - 第一节:OpenAI API 架构与基础调用
  • TensorFlow简单的线性回归任务
  • 【视频+图文详解】HTML基础4-html标签的基本使用
  • 在Arm芯片苹果Mac系统上通过homebrew安装多版本mysql并解决各种报错,感谢deepseek帮助解决部分问题
  • c++可变参数详解
  • 【深度分析】DeepSeek 遭暴力破解,攻击 IP 均来自美国,造成影响有多大?有哪些好的防御措施?
  • CMake项目编译与开源项目目录结构
  • 完全卸载mysql server步骤
  • C#方法(练习)
  • Unity游戏(Assault空对地打击)开发(3) 摄像机的控制
  • ChatGPT-4o和ChatGPT-4o mini的差异点
  • SQL进阶实战技巧:某芯片工厂设备任务排产调度分析 | 间隙分析技术应用
  • 【力扣】438.找到字符串中所有字母异位词
  • 2024具身智能模型汇总:从训练数据、动作预测、训练方法到Robotics VLM、VLA
  • Day33【AI思考】-函数求导过程 的优质工具和网站
  • 【URL】一个简单基于Gym的2D随机游走环境,用于无监督强化学习(URL)
  • 【VM】VirtualBox安装ubuntu22.04虚拟机
  • MySQL的GROUP BY与COUNT()函数的使用问题
  • C# 精炼题18道题(类,三木运算,Switch,计算器)
  • 96,【4】 buuctf web [BJDCTF2020]EzPHP
  • 数据库 - Sqlserver - SQLEXPRESS、由Windows认证改为SQL Server Express认证进行连接 (sa登录)
  • 2025年02月02日Github流行趋势