直观理解ECC椭圆曲线加密算法

数学还是挺有逻辑的,给出计算的操作步骤 就能得出想要结果

在这里插入图片描述

背景:
● ECC 是一种极其巧妙的 非对称加密算法 , 其完美利用了 椭圆曲线几何累加 不可逆的性质
● 拥有 密钥体积小,计算速度快的优势,被广泛用于各种区块链,移动端APP的认证过程。
● 越来越多的行业采用 ECC,替代传统 RSA 算法(RSA 算法的一些笔记,可以参考我上半年的部分记录 [Security] RSA原理 | 快速幂求解


一、ECC 核心原理

1.1 椭圆曲线的数学定义

椭圆曲线的标准形式为:
y 2 = x 3 + a x + b y^2 = x^3 + ax + b y2=x3+ax+b
需满足约束条件 4 a 3 + 27 b 2 ≠ 0 4a^3 + 27b^2 \neq 0 4a3+27b2=0,确保曲线无奇点(如尖点或自相交)。在密码学实践中,椭圆曲线通常定义在有限域上:
y 2 ≡ x 3 + 2 x + 3 ( mod  7 ) y^2 \equiv x^3 + 2x + 3 \ (\text{mod}\ 7) y2x3+2x+3 (mod 7)
所有坐标点均为整数,形成离散的椭圆曲线点集。

1.2 椭圆曲线群运算

运算类型计算规则数学表达式
点加法连接两点的直线与曲线的第三个交点取对称 R = P + Q R = P + Q R=P+Q
标量乘法重复点加法运算 k P = P + ⋯ + P ⏟ k 次 kP = \underbrace{P + \cdots + P}_{k\ \text{次}} kP=k  P++P
无穷远点群运算的零元素 P + O = P P + O = P P+O=P

二、ECC 安全机制

2.1 椭圆曲线离散对数问题(ECDLP)

给定点 Q = k P Q = kP Q=kP,求解整数 k k k 的难度构成 ECC 的核心安全性。相较于 RSA 算法:

  • 密钥效率:256 位 ECC ≈ 3072 位 RSA
  • 计算复杂度最佳攻击算法复杂度为 O ( n ) O(\sqrt{n}) O(n ),远超 RSA 的亚指数复杂度

2.2 抗量子计算特性

当前量子计算机对 ECDLP 最有效的 Shor 算法需要数千量子比特,远超出当前技术水平(2025 年 IBM 量子计算机仅 1121 量子比特)。但需关注后量子密码学进展,如 NIST 正在评估的 SIKE 方案。


三、ECC 应用场景

3.1 区块链技术

应用案例技术细节安全参数
比特币采用 secp256k1 曲线
公钥生成公式: Q = k G Q = kG Q=kG
私钥 256 位
公钥 512 位
以太坊ECDSA 签名算法
交易哈希算法:Keccak256
签名长度 64 字节

3.2 安全通信协议

  • TLS 1.3:支持 X25519 曲线,密钥交换速度比 RSA 快 3 倍
  • 国密标准:SM2 算法采用 256 位素数域椭圆曲线

3.3 物联网安全

在 ESP32 芯片中,ECC-256 签名仅需 5ms,功耗较 RSA-2048 降低 82%。


四、ECC 实验作业

在这里插入图片描述


一、公钥计算 Q = 5G

椭圆曲线参数
E : y 2 ≡ x 3 + 2 x + 3 ( mod  7 ) E: y^2 \equiv x^3 + 2x + 3 \ (\text{mod}\ 7) E:y2x3+2x+3 (mod 7)
基点 G = ( 2 , 1 ) G = (2, 1) G=(2,1)
私钥 k = 5 k = 5 k=5

1. 计算 2G(点加倍)

s = 3 x 1 2 + a 2 y 1 m o d 7 = 3 ⋅ 2 2 + 2 2 ⋅ 1 = 0 m o d 7 x 3 = s 2 − 2 x 1 = 0 − 4 = 3 m o d 7 y 3 = s ( x 1 − x 3 ) − y 1 = 0 ⋅ ( 2 − 3 ) − 1 = 6 m o d 7 2 G = ( 3 , 6 ) \begin{aligned} s &= \frac{3x_1^2 + a}{2y_1} \mod 7 = \frac{3 \cdot 2^2 + 2}{2 \cdot 1} = 0 \mod 7 \\ x_3 &= s^2 - 2x_1 = 0 - 4 = 3 \mod 7 \\ y_3 &= s(x_1 - x_3) - y_1 = 0 \cdot (2 - 3) - 1 = 6 \mod 7 \\ 2G &= (3, 6) \end{aligned} sx3y32G=2y13x12+amod7=21322+2=0mod7=s22x1=04=3mod7=s(x1x3)y1=0(23)1=6mod7=(3,6)

2. 计算 3G = 2G + G(点相加)

s = y 2 − y 1 x 2 − x 1 m o d 7 = 1 − 6 2 − 3 = 5 m o d 7 x 3 = s 2 − x 1 − x 2 = 25 − 3 − 2 = 6 m o d 7 y 3 = s ( x 1 − x 3 ) − y 1 = 5 ⋅ ( 3 − 6 ) − 6 = 0 m o d 7 3 G = ( 6 , 0 ) \begin{aligned} s &= \frac{y_2 - y_1}{x_2 - x_1} \mod 7 = \frac{1 - 6}{2 - 3} = 5 \mod 7 \\ x_3 &= s^2 - x_1 - x_2 = 25 - 3 - 2 = 6 \mod 7 \\ y_3 &= s(x_1 - x_3) - y_1 = 5 \cdot (3 - 6) - 6 = 0 \mod 7 \\ 3G &= (6, 0) \end{aligned} sx3y33G=x2x1y2y1mod7=2316=5mod7=s2x1x2=2532=6mod7=s(x1x3)y1=5(36)6=0mod7=(6,0)

3. 计算 4G = 3G + G(点相加)

s = y 2 − y 1 x 2 − x 1 m o d 7 = 1 − 0 2 − 6 = 5 m o d 7 x 3 = s 2 − x 1 − x 2 = 25 − 6 − 2 = 3 m o d 7 y 3 = s ( x 1 − x 3 ) − y 1 = 5 ⋅ ( 6 − 3 ) − 0 = 1 m o d 7 4 G = ( 3 , 1 ) \begin{aligned} s &= \frac{y_2 - y_1}{x_2 - x_1} \mod 7 = \frac{1 - 0}{2 - 6} = 5 \mod 7 \\ x_3 &= s^2 - x_1 - x_2 = 25 - 6 - 2 = 3 \mod 7 \\ y_3 &= s(x_1 - x_3) - y_1 = 5 \cdot (6 - 3) - 0 = 1 \mod 7 \\ 4G &= (3, 1) \end{aligned} sx3y34G=x2x1y2y1mod7=2610=5mod7=s2x1x2=2562=3mod7=s(x1x3)y1=5(63)0=1mod7=(3,1)

4. 计算 5G = 4G + G(点相加)

s = y 2 − y 1 x 2 − x 1 m o d 7 = 1 − 1 2 − 3 = 0 m o d 7 x 3 = s 2 − x 1 − x 2 = 0 − 3 − 2 = 2 m o d 7 y 3 = s ( x 1 − x 3 ) − y 1 = 0 ⋅ ( 3 − 2 ) − 1 = 6 m o d 7 5 G = Q = ( 2 , 6 ) \begin{aligned} s &= \frac{y_2 - y_1}{x_2 - x_1} \mod 7 = \frac{1 - 1}{2 - 3} = 0 \mod 7 \\ x_3 &= s^2 - x_1 - x_2 = 0 - 3 - 2 = 2 \mod 7 \\ y_3 &= s(x_1 - x_3) - y_1 = 0 \cdot (3 - 2) - 1 = 6 \mod 7 \\ 5G &= Q = (2, 6) \end{aligned} sx3y35G=x2x1y2y1mod7=2311=0mod7=s2x1x2=032=2mod7=s(x1x3)y1=0(32)1=6mod7=Q=(2,6)


二、ECC 加密明文 P = (3, 1)

随机因子 r = 3 r = 3 r=3
公钥 Q = ( 2 , 6 ) Q = (2, 6) Q=(2,6)

1. 计算密文分量 C₁ = rG

C 1 = 3 G = ( 6 , 0 ) (已计算) C₁ = 3G = (6, 0) \quad \text{(已计算)} C1=3G=(6,0)(已计算)

2. 计算 rQ = 3Q

2Q(点加倍)
s = 3 x 1 2 + a 2 y 1 m o d 7 = 14 12 = 0 m o d 7 x 3 = 0 − 4 = 3 m o d 7 y 3 = 0 ⋅ ( 2 − 3 ) − 6 = 1 m o d 7 2 Q = ( 3 , 1 ) \begin{aligned} s &= \frac{3x_1^2 + a}{2y_1} \mod 7 = \frac{14}{12} = 0 \mod 7 \\ x_3 &= 0 - 4 = 3 \mod 7 \\ y_3 &= 0 \cdot (2 - 3) - 6 = 1 \mod 7 \\ 2Q &= (3, 1) \end{aligned} sx3y32Q=2y13x12+amod7=1214=0mod7=04=3mod7=0(23)6=1mod7=(3,1)

3Q = 2Q + Q(点相加)
s = 6 − 1 2 − 3 = 2 m o d 7 x 3 = 4 − 3 − 2 = 6 m o d 7 y 3 = 2 ⋅ ( 3 − 6 ) − 1 = 0 m o d 7 3 Q = ( 6 , 0 ) \begin{aligned} s &= \frac{6 - 1}{2 - 3} = 2 \mod 7 \\ x_3 &= 4 - 3 - 2 = 6 \mod 7 \\ y_3 &= 2 \cdot (3 - 6) - 1 = 0 \mod 7 \\ 3Q &= (6, 0) \end{aligned} sx3y33Q=2361=2mod7=432=6mod7=2(36)1=0mod7=(6,0)

3. 计算密文分量 C₂ = P + rQ

s = 0 − 1 6 − 3 = 2 m o d 7 x 3 = 4 − 3 − 6 = 2 m o d 7 y 3 = 2 ⋅ ( 3 − 2 ) − 1 = 1 m o d 7 C 2 = ( 2 , 1 ) \begin{aligned} s &= \frac{0 - 1}{6 - 3} = 2 \mod 7 \\ x_3 &= 4 - 3 - 6 = 2 \mod 7 \\ y_3 &= 2 \cdot (3 - 2) - 1 = 1 \mod 7 \\ C₂ &= (2, 1) \end{aligned} sx3y3C2=6301=2mod7=436=2mod7=2(32)1=1mod7=(2,1)

结果:

公钥 Q = (2, 6)
密文 (C₁, C₂) = ((6, 0), (2, 1))

五、ECC 发展

5.1 后量子密码学

研究重点转向同源密码和超奇异椭圆曲线同源,可在保持 ECC 效率的同时抵抗量子攻击。

5.2 标准化进程

NIST 已发布 SP 800-186 标准,新增 Curve448 等高安全曲线,逐步替代 RSA。


核心公式速查表
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/38682.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深度解析 Android Matrix 变换(二):组合变换 pre、post

前言 在上一篇文章中,我们讲解了 Canvas 中单个变换的原理和效果,即缩放、旋转和平移。但是单个旋转仅仅是基础,Canvas 变换最重要的是能够随意组合各种变换以实现想要的效果。在这种情况下,就需要了解如何组合变换,以…

c++之迭代器

一.迭代器的基本概念 1.什么是迭代器 迭代器是一种对象,它提供了一种访问容器中各个元素的方法,同时隐藏了容器内部的实现细节。简单来说,迭代器就像是一个指针,它可以指向容器中的某个元素,并且能够通过一些操作&am…

在 .NET 9.0 Web API 中实现 Scalar 接口文档及JWT集成

示例代码:https://download.csdn.net/download/hefeng_aspnet/90408075 介绍 随着 .NET 9 的发布,微软宣布他们将不再为任何 .NET API 项目提供默认的 Swagger gen UI。以前,当我们创建 .NET API 项目时,微软会自动添加 Swagger…

【操作系统笔记】操作系统的功能

上节课,我们学习了《什么是操作系统》。接下来,我们来看看操作系统有哪些功能? 这里讲的内容有两部分,一个是操作系统的目标,另外一个就是操作系统的功能。这两个细节可能会在考试的时候考到,但是最近好些年很少考到了。为了理解,我们还是一起来看一下。 操作系统的目标…

C/C++蓝桥杯算法真题打卡(Day7)

一、P8723 [蓝桥杯 2020 省 AB3] 乘法表 - 洛谷 算法代码&#xff1a; #include<bits/stdc.h> // 包含标准库中的所有头文件&#xff0c;通常用于竞赛编程中简化代码 using namespace std; // 使用标准命名空间&#xff0c;避免每次调用标准库函数时都要加std:: ty…

数据结构5(初):排序

目录 1、排序的概念以及常见的排序算法 1.1、排序的概念 1.2、常见的排序算法 2、常见排序算法的实现 2.1、插入排序 2.1.1、直接插入排序 2.1.2、希尔排序 2.2、选择排序 2.2.1、直接选择排序 2.2.2、堆排序 2.3、交换排序 2.3.1、冒泡排序 2.3.2、快速排序 2.3.…

VS2022中通过VCPKG安装的ceres之后调试ceres的例程设置

1.采用C20. vcpkg中设置: 2.增加预处理宏: GLOG_USE_GLOG_EXPORT 3.屏蔽sdl错误 在 项目-属性-C/C -命令行中添加 /sdl /w34996 #include "ceres/ceres.h" //#include <iostream> //#include<glog/logging.h>using ceres::AutoDiffCostFunction; usi…

Pydantic字段级校验:解锁@validator的12种应用

title: Pydantic字段级校验:解锁@validator的12种应用 date: 2025/3/23 updated: 2025/3/23 author: cmdragon excerpt: Pydantic校验系统支持通过pre验证器实现原始数据预处理,在类型转换前完成字符清洗等操作。格式验证涵盖正则表达式匹配与枚举值约束,确保护照编号等字…

函数递归和迭代

1.什么是递归&#xff1f; 在C语言中递归就是自己调用自己。 看一下简单函数的递归&#xff1a; 上面的代码实现演示一下函数的递归&#xff0c;最终是会陷入死循环的&#xff0c;栈溢出 。 1.1递归的思想&#xff1a; 把一个大型的问题一步一步的转换成一个个小的子问题来解…

发票查验/发票验真如何用Java实现接口调用

一、什么是发票查验&#xff1f;发票验真接口&#xff1f; 输入发票基本信息发票代码、发票号码、开票日期、校验码后6位、不含税金额、含税金额&#xff0c;核验发票真伪。 该接口也适用于机动车、二手车销售发票、航空运输电子客票、铁路电子客票等。 二、如何用Java实现接口…

AM32-MultiRotor-ESC项目固件编译和烧录方法介绍

AM32-MultiRotor-ESC项目固件编译和烧录方法介绍 &#x1f4cd;AM32-MultiRotor-ESC项目地址:https://github.com/AlkaMotors/AM32-MultiRotor-ESC-firmware&#x1f388;Updater with V8 Bootloader&#xff1a; https://github.com/AlkaMotors/F051_Bootloader_Updater&#…

HarmonyOS:@AnimatableExtend 装饰器自学指南

在最近的项目开发中&#xff0c;我遇到了需要实现复杂动画效果的需求。在探索解决方案的过程中&#xff0c;我发现了 AnimatableExtend 装饰器&#xff0c;它为实现动画效果提供了一种非常灵活且强大的方式。然而&#xff0c;在学习这个装饰器的过程中&#xff0c;我发现相关的…

Windows server 2022域控制服务器的配置

Windows server 2022介绍 一、核心特性与改进 安全核心服务器&#xff08;Secured-Core Server&#xff09; 硬件级安全&#xff1a;支持基于硬件的安全功能&#xff08;如TPM 2.0、Secure Boot、基于虚拟化的安全防护VBS&#xff09;&#xff0c;防止固件攻击。受信任的启动链…

C++语法之模板函数和模板类

模板函数是什么&#xff1f;就是不指定类型的函数&#xff0c;不指定类型如何写代码?所以得用到模板&#xff0c;可以先用模板代替&#xff0c;就好像方程式&#xff0c;先用x,y代替一样。 它的写法是这样&#xff0c;定义函数时&#xff0c;开头加一句:(其中的T就相当于x,y之…

时序分析笔记

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 前言 一、周期约束 二、建立时间和保持时间 三、时序路径 四、时序模型 前言 约束文件笔记&#xff0c;傅里叶的猫的视频。 一、周期约束 时序约束就是告诉软件输…

六十天前端强化训练之第二十八天之Composition 函数完全指南

欢迎来到编程星辰海的博客讲解 看完可以给一个免费的三连吗&#xff0c;谢谢大佬&#xff01; 目录 一、核心概念解析 1.1 什么是 Composition 函数 1.2 为什么需要封装 1.3 设计原则 二、实战案例&#xff1a;鼠标跟踪器 2.1 未封装版本 2.2 封装后的 Composition 函数…

MySQL 锁机制详解

MySQL 锁机制详解 5.1 概述 锁是计算机协调多个进程或线程并发访问某一资源的机制。在数据库中&#xff0c;除传统的计算资源&#xff08;CPU、 RAM、I/O&#xff09;的争用以外&#xff0c;数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性、有 效性是所有数…

常见中间件漏洞攻略-Apache篇

漏洞名称&#xff1a;Apache HTTP Server 路径穿越漏洞-CVE-2021-41773 第一步&#xff1a;拉取环境、启动环境 #拉取环境 docker pull blueteamsteve/cve-2021-41773:no-cgidhttp://121.40.229.129:8080#启动环境 docker run -dit -p 8080:80 blueteamsteve/cve-2021-41773:n…

站群服务器是什么意思呢?

站群服务器是一种专门为托管和管理多个网站而设计的服务器&#xff0c;其核心特点是为每个网站分配独立的IP地址。这种服务器通常用于SEO优化、提高网站权重和排名&#xff0c;以及集中管理多个网站的需求。以下是站群服务器的详细解释&#xff1a; 一、站群服务器的定义 站群…

Excel 小黑第22套

对应大猫22 新建一行&#xff0c;输入第一个人名字&#xff0c; 填充 -快速填充 修改员工编号&#xff08;1—001&#xff09;&#xff1a;选中所有员工编号&#xff0c;开始 -数据组 -自定义数字格式 000 在所有空表格单元格中输入数字0&#xff1a;选中修改的表格范围&#…