【密码学】大整数分解问题和离散对数问题

公钥密码体制的主要思想是通过一种非对称性,即正向计算简单,逆向计算复杂的加密算法设计,来解决安全通信。本文介绍两种在密码学领域内最为人所熟知、应用最为广泛的数学难题------大整数分解问题与离散对数问题

一、大整数分解问题

(1)问题的定义

假设 𝑁 是一个合数,且 𝑁=𝑝×𝑞,其中 𝑝 和 𝑞 都是大于1的大质数(又叫素数)。大整数分解问题的目标是,仅给定 𝑁,找到 𝑝 和 𝑞。更一般地,问题是找到所有质数因子,而不仅仅局限于两个因子的情况。

【注】质数(Prime Number)是指在大于1的自然数中,除了1和它本身以外不再有其他因数的数。换句话说,质数只能被1和它自身整除。例如,2、3、5、7、11、13等都是质数。

(2)非对称性的体现

  • 正向计算容易:找到两个大素数并计算它们的乘积是非常简单的。现代计算机可以迅速地找到这样的素数并对它们执行乘法操作。
  • 逆向计算困难:然而,给定𝑛来找出它的两个素数因子𝑝和𝑞是非常困难的。随着𝑛的位数增加,分解𝑛所需的计算资源呈指数级增长。当前的算法,在分解大整数时需要耗费大量的时间和计算能力,这使得在合理的时间内分解大整数变得不切实际。

(3)密钥生成与加解密简述

① 密钥生成算法

随机选择两个大素数p和q;计算;计算欧拉函数;选择一个整数e,使得1 < e < φ(N),且e与φ(N)互质;计算d作为e关于φ(N)的模逆元,即找到d满足de ≡ 1 (mod φ(N));

  • 公钥是(N, e),其中N是模数,e是加密指数;
  • 私钥是(d, N),其中d是解密指数,N同样是模数。

② 加密算法

发送方使用接收方的公钥对明文进行加密,生成密文

加密过程通常表示为

③ 解密算法

接收方使用自己的私钥对密文进行解密,恢复出明文

解密过程表示为
以RSA为例

二、离散对数问题

(1)问题的定义

给定一个有限域 G,以及该域中的一个生成元(或称为基)一个元素 ,离散对数问题可以这样表述:

对于任意给定的G中的非零元素,找到一个整数,使得次方模上 等于,即

如果这样的 存在,则称 相对于基 的离散对数。这里的"离散"一词,是因为群G通常是一个离散集合,而不是连续的。

【注】G称为模 𝑝 的有限域,其中 𝑝 必须是一个素数。这样所有加法、减法、乘法和除法运算的结果都会被取模 𝑝 来确保结果仍然在这个有限域内。

(2)非对称性的体现

  • 正向计算容易 :计算是非常直接且快速的,可以通过快速幂算法在多项式时间内完成。
  • 逆向计算困难:然而,给定𝑔和𝑦,找到𝑥是非常困难的,特别是在𝑝非常大的情况下。目前没有已知的多项式时间算法能够解决这个问题,尽管存在一些算法可以优化搜索过程,但当𝑝足够大时,这些算法仍然需要指数级的时间。

(3)密钥生成与加解密简述

① 密钥生成算法

以ElGamal加密算法为例。

  1. 选择一个大素数 p 、一个原根 g 和模 p。原根意味着 g 的所有幂次模 p 将遍历所有非零的模 p 的剩余类。

  2. 选择私钥 ,这是一个小于 的随机整数。

  3. 计算公钥 ,其中

公钥是,而私钥是

② 加密算法

假设 Alice 想要向 Bob 发送一条消息 ,并且 Bob 的公钥是

  1. 选择一个随机数 𝑘,其中 1<𝑘<𝑝−1

  2. 计算第一个加密分量

  3. 计算第二个加密分量

加密后的消息是

③ 解密算法

Bob 收到加密消息后,使用他的私钥 来解密:

  1. 计算中间值

  2. 计算消息

这里的 是指 𝑠 在模 𝑝 下的乘法逆元,也就是说,找到一个数 𝑧,使得

相关推荐
deepdata_cn2 天前
量子-resistant密码学研究
密码学·量子计算
Evaporator Core6 天前
信息安全工程师软考进阶:第二章密码学与应用深度习题解析
密码学
長琹7 天前
AES加密算法详细加密步骤代码实现--身份证号码加解密系统
网络·数据库·人工智能·python·密码学
有点不太正常7 天前
《A Study of Probabilistic Password Models》(IEEE S&P 2014)——论文阅读
论文阅读·密码学·口令猜测·马尔可夫链
Blockchain Learning8 天前
椭圆曲线的数学基础
golang·密码学
yjx2333210 天前
《应用密码学》——基础知识及协议结构模块(笔记)
笔记·密码学
默辨10 天前
密码学基础
密码学·非对称加密·数字签名·对称加密·摘要加密
浩浩测试一下13 天前
Windows驱动开发与双机调试环境[驱动开发环境配置高阶]
安全·web安全·网络安全·密码学·网络攻击模型·安全架构
东皇太星15 天前
模运算(密码学/数论/算法)
数据结构·算法·密码学
蒋星熠15 天前
区块链技术探索与应用:从密码学奇迹到产业变革引擎
python·语言模型·web3·去中心化·区块链·密码学·智能合约